rr 


= = RF F signal generator 


— 


Mp Daromeie i limeter, 
mveg data 


fmartcard-£ 
operated 7 
safety log 


Ot i 


eFID 3 Ko 
sysiems ™ 0 


MN 


ULL 


November 1998 Number 271 


Elektor Electronics 
Volume 24 
ISSN 0268/4519 
= = 2 


56 
developed a new 
requency |Den- 
RF signal generator - Part 1 30 PC control for Mini-Dise player 
This RF signal A design for 
generator covers a controlling a 
} frequency range of Sony Mini-Disc 
: 0.5-30 MHz and deck via a PC. 
has an output level Design by P. 
range of 0 dBm to Glatzel 
-79 dBm. 
Design by 
Guido Brunner 
18 Versatile control system PLC87(A) : 
— Part 2 48 Barometer/altimeter 
The second and last instalment of the article A design based on a 
Type MPXS4100A 


precision gir-pressure 
sensor with integral 
signal processor from 
Motorola. 

Design by 

H. Bonekamp 


explains the operation of some of the more 
important instructions. 
Design by R. Geugelin 


24 Smart card operated safety lock 
A design for giving expired smart cards a new 
lease of life. 

Design by Patrick Gueulle 


| 
: 
| 
. 
! 
| 
| 
describes the way commands are written and 
: 


ME THIS MONTH 
IN PC-TOPICS: 


Atmel AVR-2 

PC keyboard switcher 
CD-R formats 
Compact display drive 
Master/slave switch 


V VV VF 


Copyright © 1998 Segment BV 


receivers, whether 
ne-made, restored 
surplus or off-the- 
shelf. The generator 
ribed here has an 

output frequency 
_ range of 0.5 to 
30 MHz, making it 
suitable for many 
applications. 


i Frequency range: 
i Output level: 

im Max, output level: 
im Output impedance: 

im AM input 

i FIVE input 

ity LCD readout 

ws» Microprocessor controlled 
in Optional serial interface 
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RADIO, TELEVISION & VIDEO 


A rock-solid RF signal with an accu- 
rately known frequency and level is a 
must for anyone seriously involved in 
repairing radio receivers and other 
communications equipment like filters 
and even antennas. In particular, 


Main specifications 


0.5 MHz to 30 MHz 


0 dBm down to -79 dBm in 1-0B steps 


0.63Vp, into 50 Q 
50 Q 


receiver RF input and IF (intermediate 
frequency) sections can not be tested 
with any degree of certainty if a trust- 
worthy RF signal generator is not to 
hand. Unfortunately, professional- 
grade RF signal generators (like the 
mighty Hewlett Packard 8640B in our 
design lab) cost an arm and a leg, even 
in the surplus trade. None the less, you 
will see at least one RF signal generator, 
home-made, thrown together from 
other bits and pieces, or ex-MOD, in 
the shack of the more advanced radio 
amateur, simply because this piece of 
test gear is as indispensable as the plain 
old multimeter. 

The stability of the RF signal gen- 
erator described in this article is such 
that it will meet the (moderate) 
demands of many amateurs. Offering 
a frequency range of 0.5 through 
30 MHz and an output level down to 
-80 dBm, it is perfect for testing and 
aligning many receivers and their sub- 
circuits like RF/IF amplifiers, mixers 


Elektor Electronics 11/98 


Visit our Web site at http://ourworld.compuserve.com/homepages/elektor_uk 


and demodulators. 

What requirements can be men- 
tioned in relation to an RF signal gen- 
erator? The answer is very simple 
indeed: you need to be sure of (1) the 
frequency and (2) the level of the signal 
you feed into the circuit (receiver) 
under test. If either of these is unreli- 
able, all testing and comparing of 
receiver specs becomes meaningless. 
In the present design, frequency sta- 
bility is assured by a PLL (phase- 
locked loop), while the output level is 
determined by a switched pi (pi) atten- 
uator, all under the control of a micro- 
processor. 


BLOCK DIAGRAM 
Because the actual circuit diagrams of 
the four modules that make up the sig- 
nal generator are a fairly complex lot 
when presented together, it was 
decided to draw and dis- 
cuss them as separate 
blocks. The 
basic interac- 
tion of 
these blocks 
is illustrated 
in Figure 1. 
The — block 
diagram 
shows _ that 
the heart of 
the circuit is 
a PLL syn- 
thesizer mod- 
ule keeping a 
VCO  (volt- 
age-controlled 
oscillator) in check. The 
VCO output signal is amplified and 
fed to the generator output as well to 
the synthesizer input and the input of 
the attenuator. The PLL obtains digital 
information on the target VCO fre- 
quency from a microprocessor module. 
The micro also takes care of the front- 
panel mounted user interface, which 
consists of 3 switches, a rotary encoder 
and an LCD (liquid-crystal display). It 
also controls the amount of attenuation 
at the generator output, across a range 
of -1 dB through ~79 dB. An optional 
serial interface is available to enable the 
RF Signal Generator to be linked toa 
PC using an RS232 cable. Functionally, 
the instrument is completed by an 

internal power supply. 


PLL BOARD 

The circuit diagram of this first module 
to be discussed in detail is shown in 
Figure 2. It comprises three sub-cir- 
cuits: VCO, synthesizer and output 
buffer. The VCO and the synthesizer 
together from the PLL. 


VCO and buffers 

The active element in the oscillator is a 
differential amplifier built around tran- 
sistors Tl, T2 and T3, whose gain 
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depends on the current 
passed by T3. The actual 
resonating element in 
the oscillator is an L-C 
parallel tuned circuit 
connected to the input 
of the difference amplifier. The LC net- 
work consists of inductors L1-L5 in 
combination with variable-capacitance 
diodes (varicaps) D9 and D10. The 
other input of the oscillator is 
grounded for RF by capacitor C10. 
Depending on the desired frequency 
range, one or more inductors are 
switched into the oscillator. This is 
done by pulling the non-commoned 
terminals to RF ground using +5V 
control voltages on PIN diodes D2, D4, 
D6 and D8. In the highest frequency 
range, all inductors are effectively con- 
nected in parallel. This is necessary to 
make sure that the non-selected induc- 
tors and their parasitic capacitance can 
not form a series tuned circuit that 
would prevent the oscillator from 
operating at the desired frequency. All 
inductors are off-the-shelf miniature 
chokes. The frequency range switching, 
takes place at 1,024 MHz, 2.304 MHz, 
5.376 MHz and 13.056 MHz. 
Capacitor C8 provides the neces- 
sary amount of positive feedback in the 
oscillator. An AF signal may be applied 
to the emitter of T4 to effect amplitude 
modulation (AM). Frequency modula- 
tion (FM) is also possible by superim- 
posing an AF signal onto the varicap 
tuning voltage. Although FM will 
cause the PLL to drop out of lock, the 
average frequency remains constant 
because the time constant of the con- 


Attenuator 
0...- 79 dB 


trol loop is not capable 
of tracking the ‘insta- 
bility’ caused by the 
modulation signal. 

To make sure it is 
not too heavily loaded, 
the oscillator signal is first buffered by a 
FET (field-effect transistor), T4. Next 
comes the real amplifier, [C1], a type 
NE592 which some of you may know 
from baseband-video amplifiers in 
satellite-TV receivers. The amplifier is 
biased at half the supply voltage by 
opamp IC3b, and its gain is defined by 
series network R26-L8. Because of the 
inductor action, the gain decreases at 
higher frequencies. Because the VCO 
strives to maintain a stable output 
level, less gain on the NE592 automat- 
ically more gain in the differential oscil- 
lator. This purposely-created effect is 
essential for reliable starting of the 
oscillator at higher frequencies. 

The NE592 being a differential 
amplifier, it has two inputs, but also 
outputs. Both are used here. The signal 
at the first output (pin 7) is applied to 
emitter follower T5 which supplies the 
actual generator output signal at an 
impedance of 50 Q (the standard in RF 
test equipment). The other output sig- 
nal supplied by the NE592 is used to 
drive two sub-circuits. One branch 
goes to the PLL chip via C23 and R33, 
the other is used to drive a voltage rec- 
tifier/doubler, D11-D12 which in turn 
drives amplitude-control opamp IC3a. 
The desired highest output amplitude 
may be set using preset P1. The author 
used a setting where 0 dBm (decibel- 
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milliwatt) into 50 &2 equals 0.63 V,, at 
the generator output. 


Synthesizer 

The circuit of the synthesizer largely 
follows the Application Note for the 
SAA1057 as supplied by Philips Semi- 
conductors. Some component values 


T1 ... T8 = BCS57B 


MAX232 
hee 


in the control loop had to be modified a 
little to optimise the behaviour of the 
PLL. The ‘LOCK’ output is only pro- 
vided for test purposes. The SAA1057 
receives its contro] information in I2C 
format via its SDA, SCL and DLEN 
inputs. These lines are connected toa 
microcontroller. Basically, the SAA1057 
compares the frequency of the VCO 
with that of a reference signal derived 
from the external 44MHz quartz crys- 
tal. For this purpose the VCO signal is 
internally divided by a factor deter- 
mined by the microprocessor. The fre- 
quency difference produces an error 
signal which is converted into a corre- 


11.059 MHz 


C6... C10 =10u / 63V 


Over the past 11 years ULTImate Technology supplied more than 20.000 


commercial versions, but also thous 
(high resolution f 


no Gerber Interfac 


is of educational versions, which, having § 
toplotter) are not suitable for commercial § 


use, but are otherwise, identical to the, naturally far more expensi 
versions, After a worldwide test on Internet the ULTIboard Studio evolved, with s 
the same well-considered limitation, at a price at which everybody can afford 


a professional design system. 


SEE ALS@ THE REPLYCARD ELSEWHERE 
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DGCLK 
OGDIR 


sponding varicap control voltage. This 
control voltage is integrated by R40- 
C37 and has a range of 0-30 V. Remark- 
ably, the SAA1057 does not require an 
external level converter for the varicap 
control voltage — a special amplifier is 
included on the chip for this purpose, 
as well as a direct connection for +30 V 
(pin 7). 

Trimmer C33 allows the generator 
output frequency to be calibrated 
against a frequency standard. 

The VCO/PLL board requires three 
supply voltages: +5 V for the synthe- 
sizer, +12 V for the VCO, and +30 V 
for the varicap voltage. 


Sv 


T9... T12 = BC557B 


5v 
+5V 
cu 
mI ei 
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ATTENUATOR BOARD 
Figure 3 shows the circuit diagram of a 
digitally controlled 8-section pi RF 
attenuator with a range of —1 dB to 
-79 dB in 1-dB steps. The resistor com- 
binations we need to realize each of 
the 79 discrete attenuation levels are 
connected into the circuit by means of 
relay contacts. The associated relays are 
actuated and de-actuated by micro- 
processor drive signals that form 8-bit 
combinations at the control inputs 
marked A1-A8. 

The theoretical values of the resis- 
tors in the attenuator are realized by 
means of parallel combinations of 1% 
resistors from the E96 series. 

Each relay coil is shunted by a back- 
emf suppressor diode and a decou- 
pling capacitor. 


MICROCONTROLLER 
BOARD 

All the intelligence we need to imple- 
ment a man/machine interface, i.e., 
establish communication between the 
user on the one hand, and the PLL and 
the attenuator on the other, is packed 
in a microcontroller type 89C51. This 
controller executes a program written 


C1... C4 = 4x 470 
D1 ... D4 = 4x 1N4001 
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by the author and burned into the 
internal program memory by the Pub- 
lishers. The 89C51 is available ready- 
programmed from the Publishers or 
certain kit suppliers advertising in this 
magazine. 

The 89C51 accepts information and 
supplies information. Microcontroller 
freaks call this ‘I/O’ for input/output. 
Well, the input devices are a rotary 
shaft encoder, $4, which is used for the 
frequency setting, a small keyboard, 
$1-S2-S3, the SDA line of the I?C bus 
and (optionally) the RxD line of the 
MAX232 serial interface. The output 
devices to control are the LCD con- 
nected to port PO, the attenuator on 
port P1), the VCO inductors on port 
line P2.0 through P2.3 and, of course, 
the synthesizer chip, by way of the 
DDA and SCL lines (P2.6 and P2.7). 
Actually, the IC bus is modified into a 
so-called CBUS by the addition of P2.5 
(DLEN) and its pull-up resistor, R2. 

The 89C51 is clocked at 
11.0592 MHz by an external quartz 
crystal, X1. This frequency was chosen 
because it allows standard baud rates 
to be used on the serial interface. 

A classic power-on reset network, 
R1-C1, completes the microcontroller 
circuit. 

This board requires only +5 V to 
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operate, the MAX232 having on-chip 
step-up converters for +10 V and 
-10V. 


POWER SUPPLY BOARD 
As you can see from the circuit dia- 
gram in Figure 5, the power supply for 
the RF signal generator is entirely con- 
ventional. 

The 30-V varicap supply is based on 
a simple combination of a zener diode 
and a series transistor, Current drain 
on the 30-¥ rail will be very small, so 
extensive regulation is not necessary. 
None the less, a fair number of decou- 
pling capacitors is used to keep the var- 
icap voltage as clean as possible. After 
all, all hum, noise etc. on this rail will 
cause frequency modulation on the 
output signal. The input voltage for the 
30-V regulator is supplied by a voltage 
doubler, C10-D5-D5, 

The 5-V and 12-V supplies are based 
on two old faithfuls, the 7805 and the 
LM317 respectively. These [Cs and 
their usual ‘satellite’ components have 
been used so many times in our pub- 
lished circuits that no further descrip- 
tion will be necessary. 

Asingle mains transformer rated at 
15 V, 8VA, supplies all the necessary 
alternating voltages. The mains voltage 
at the primary side is applied via a 
double-pole switch and a fuse, both 
built into a Euro-style appliance socket. 


NEXT MONTH 
In next month's second and conclud- 
ing instalment we will be discussing 
the construction of the instrument on 
four printed circuit boards. The article 
will be concluded with notes on the 
operation of the RF Signal Generator, 
miscellaneous matters and optional 
extras. 

(980053-1) 
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versatile control 
system PLC87(A) 


part 2: command list (CL) 
programming 


rhe PLC87(A) is programmed using Simatic compatible command lists 
s). A CL consists of a sequence of logic combinations and/or instruc- 
ns for the PLC to execute. In this second and last instalment we look 


at the way command lists are written, and also explain the operation of 


s of the microcontroller on the PLC87(A) board are 
in inputs and outputs which form the links between 


a is capable of using flags ened: software timers, 
and counters. When the PLC i is initialised or stopped, 


CL CL line consists of an operator and a parameter, or a 
ind and a variable. Comment may be appended, ora 


J1, ACCU2, PAE, PAA), and may be called up for pro- 
ig later. When the PE command is encountered, the 
eter returns to the start of the CL. This results in a 
response to events (cycle time). Although the values 
and outputs are updated during every cycle, their 


Design by R. Geugelin 


some of the more important instructions. 


THE COMMANDS 

The commands sent to the PLC87(A) by the PC may be 
divided into a number of groups. The Datasheets in this mag- 
azine list the English versions of the commands, together 
with their parameters, if applicable, and short descriptions. 
The Datasheets may be used as Quick Reference Cards for the 
PLC87(A) system. 


Bit combinations 
are the result of combining two bit-parameters. 


A Z x.y AND 

AN z x.y AND NOT (NAND) 
oO 2 «x.y OR 

ON Zz x.y OR NOT (NOR) 


operations. Valid parameters in position z are I, Q, F, T, C and 
(, while x represents the number of the byte, and y the num- 
ber of the bit. 


Allocations 


i 

t 
The BCR (bit combination result) is the result of these logic 
These are used to allocate a certain bit parameter to the BCR. 


set when BCR =1 
reset when BCR = 1 


s 
R z x.y 


= & uy equals (equals BCR) 


Valid parameters are Q, F and C, while x represents the num- 
ber of the byte, and y the number of the bit. 


Timer functions 
The timers T n (0-15) count down a previously loaded value. 
Various options are available. If the value becomes 0, interro- 
gating the BCR will produce a ‘1’, Before the start command, 


Elektor Electronics 11/98 


Visit our Web site at http://ourworld.compuserve.com/homepages/elektor_uk 


the timer value has to be loaded by means of L KT x.y (x=0- 
200, ¥=1, 2, 3} 


sD T start Tn, on-delayed 

SF T aA start Tn, off-delayed 

SP T no start Tn, as pulse 

SE T nn start Tn, as extended pulse 
Counter functions 


Each counter C n (0-7) has a count range of 0 through 255, 
and is capable of counting up or down. The counter value 
may be cleared, set and interrogated. A bit interrogation then 
produces a zero when the counter value is greater than 1. 


cu c ia Cn counts up on positive edge of BCR 

cD Cc a Cn counts down on positive edge of 
BCR 

R cc & set counter to 0 when BCR=1 

Ss con counter value to ACCU1 when BCR=1 

L con load counter value into ACCUL 

A c on BCR=1 when counter value > 0 

Byte combinations 


These serve to perform bit-by-bit combinations of the con- 
tents of ACCU and ACCU2. The result of the byte-combina- 
tion is left behind in ACCU1. 


AB AND byte 
XB Exclusive-OR byte 
OB OR byte 


Comparison commands 
These allow you to compare the contents of ACCUI1 and 
ACCU2, 


!=B compare for: equal 

>B compare for: greater than 

<B compare for: smaller than 

>=B compare for: greater than or equal 
<=B compare for: smaller than or equal 
><B compare for: not equal 


Arithmetic operations 
These are limited to 8-bit arithmetic. Invariably, the two accu- 
mulators are involved. 


+B aAccUl + ACCU2 = ACCU1 (carry to ACCU2) 
—B ACCU2 — ACCU1 = ACCU1 (borrow in ACCU2) 
*B aAccu2 * ACCU1 = ACCU] (carry to ACCU2) 
/B ACCU2/ACCU1 = ACCU1 (rest in ACCU2) 


As you can see, the result is always left in ACCU1, while the 
remainder, a carry bit or a borrow bit, ends up in ACCU2. To 
read ACCU2, you have to copy its contents to ACCU1 using 
the instruction TAK. 


Load commands 

The load commands offered by the CL interpreter enables 
variables or constants to be loaded into the ACCU(s). Before 
ACCU1 is actually loaded, its current value is moved to 
ACCU2. 


Lx y¥ load 

L AI x load analogue input x (PLC87A only) 

L KB y load byte constant (y = 0-255) 

L KW y load word constant (y = 0-65535) 

L KT x.y load timebase (x= 1-255, y = 1-3) 

L ¢ 3 load counter x with value 

L x load 

LI x load indirectly (x = IB, QB, FB; load 
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the contents of the input/output or 
flagbyte pointed to by ACCU1) 


n = number of counter 
IB, QB, FB, FW 
number of byte 


I 


x 
Y 


With word commands, both ACCUs are read (HighByte into 
ACCU2, LowByte into ACCUI). 


Transfer commands 
The transfer commands enable the ACCU contents to be 
moved to variables. 


T x sy (x= OB, FB, FW, y = no. of byte) 
r PR transfer to polling register 
Tr x transfer indirectly (x = QB, FB) 


(transfers contents of ACCU2 to the 
output or flagbyte pointed to by 
ACCU1) 


With word commands, both ACCUs are written to (HighByte 
into ACCU2, LowByte into ACCU1). 


ACCU commands 
The following commands only affect accumulator 1 (ACCU1): 


SLB n rotate ACCU1 by n bytes to the left 
SRB n rotate ACCU1 by n bytes to the right 
INC n increment ACCU1 by n 
DEC n decrement ACCU] by 1 
TAK swap ACCU1 and ACCU2Z contents 
BCD convert ACCU1 contents into 
BCD number 
ADJ correct ACCU for temperature sensor 


AD22100K. The range —50 °C to +150 °C 
corresponds to an ACCU contents of 0- 
200. 


Program-flow commands 
The following commands control the program flow: 


sTP halt program at end of cycle when 
BCR=1 

sTs halt program immediately when BCR=1 

NOP idle, causes empty line 

BE separate main program from subroutine 

PE must be included at end of program 


Display commands 

A number of commands are at your disposal to control a liq- 
uid-crystal display (LCD) with 2 lines of 16 characters. You 
can clear the display, position the cursor, output text strings 
as well as I, Q and F bytes. Furthermore, ACCUI may be writ- 
ten into the display as a temperature value between —50 °C 
and +205 °C, 


CLR clear display 
POS n position cursor at character n (start 


of second line at char. # 64!) 


PRT OB n write contents of output byte n into 
display 

PRT IB n write contents of input byte n into 
display 

PRT FB n write contents of flagbyte n into 
display 

PRT “STR” write character string (up to 20 


characters } 


TMP write into display the contents of 
ACCU1 as temperature value from 
—50 °C to +205 °C 


PRT commands are written at the current cursor position, 


19 


With cyclic refresh, every PRT command should be preceded 
by a POS command, if the same position is desired. If display 
commands are used without an LCD module connected, the 
PLC87(A) is likely to ‘crash’. 


Polling 

The polling register, PR, writes values in the Polling Data Stor- 
age (PDS), which is basically a cyclic memory with a capac- 
ity of 512 bytes in EEPROM. Using the command TRG the 
value stored in the PR is written to the PDS at the end of the 
cycle, whereupon the next cell in the PDS is prepared for 
being written to. These are the relevant commands: 


load input byte 1 

into polling register 
A I 6.1 when I 0.l=1 

TRG PR to PDS, one line on 


For example, the PDS may capture certain events or states 
occurring as the program is being executed, and so enable the 
results to be read or processed at a later time. Once the 
PLC87(A) board is up and running, the PDS entry starts again 
at the first line. Only one value may be written into the PDS 
for every program cycle. 


FOR EXAMPLE... 

Under this sub-heading and helped by examples we will 
introduce CL programming, The PLC87(A) controls relays 
(via driver stages) which capture input states (via optocou- 
plers) in a system using 24-V direct voltages. 


Assignment: an immersion pump which is driven via output 
0.4, should work when a switch at location ‘A’ or ‘B’ is 
switched on (High). It should stop pumping when the mini- 
mum water intake level (‘dry’) is reached. 


0.1 switch A is on input 0.1 
0.2 switch B is on input 0.2 
float switch at I 0.6 reports water 
0.4 output 0.4 switches on pump 
end of program 


Oo FR HH 
i=) 
Py 
a 


31 BOO 


* 
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Assignment: a garage door is to be closed by a motor when a 
pushbutton is actuated, but only if there is no obstacle. When 
the end position is reached, or an obstruction is encountered, 
the motor should be switched off. 


tA I 0.1 motor-on pushbutton connected to 
input 0.1 


tA I 0.2 light barrier at input 0.2 reports 
all clear 


:S Q O.4 set output 0.4 (motor on) 


:ON I 0.2 switch at I 0.2 reports occupied 
(negative interrogation) 

:ON I 0.4 switch end position reached at I 0.4 
(opener) 

:R Q O.4 reset output (motor off) 


Assignment: a horn should sound at a rate of 1 Hz when the 
motor powering a press is operating. Motor activity should 
also be indicated by a lamp. The motor runs when pushbut- 
tons 1 and 2 are pressed simultaneously. 


:0 I 0.1 pushbutton 1 
:0 I 0.3 pushbutton 2 
M 0.1 motor-on flag 
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7A F 0.1 motor-on flag 
motor output 
7= Q O.5 lamp output 


in 
re) 
o 
> 


A F 0.1 motor-on flag 
A flash rate 
:= Q O.6 horn-on output 


w 
i 
S 


Assignment: when a switch labelled ‘OPEN’ is pressed, a 
valve should open after four seconds. After switching off, the 
valve should remain open for 20 seconds. 


A I 0.1 switch, valve open 
:L KT 40.1 load time constant 40x0.1s 
start timer 1, on- delayed 


:A I 0.1 switch, valve open 
:L KT 20.2 load time constant 20x0.1s 


3SFT 2 start timer 2, off-delayed 
<A T 2 when timer 2 reports 1 
:AN I O.1 and the valve was switched off 


already 
Yr ad or the on-delay has elapsed 
:= Q 0.4 then actuate valve 


Assignment: Pulses applied to input 0.0 are to be counted 
and shown on a two-digit 7-segment display via output byte 
0. Because the display is a common-anode type, the drive sig- 
nals have to be inverted. When the counter value exceeds 99, 
or input 0.1 is actuated, the counter value is cleared. 


:A I 0.0 count pulses 


:cuc 1 on positive edge of BCR 
:L KB 99 load constant 99 

a ¢ £ compare with counter 1 
3<B when constant < counter 


:0 I 0.1 or input 0.1 is at 1 


samc 1 then reset count value 

az ¢ 1 load count value into ACCU 
:BCD change ACCU into BCD number 
:CPL invert ACCU 

:T QB O transfer to output byte 0 
:PE 


Assignment (for PLC87A with LCD only): a temperature sen- 
sor type AD22100K is connected to analogue input AIO. This 
sensor measures the temperature in an oven. The measured 
temperature is to be shown on a display, the target tempera- 
ture is 120 °C. When the oven gets hotter than 150 °C, a warn- 
ing should appear on the display. 


'L AI O read analogue value 
:ADJ ACCU do correction for AD22100 


:T FB 1 store ACCU (temp.)} in FB1l (0°C = ACCU 
contents 50) 

:POS 0 display position char. 0 

:PRT “Temperature: " 

i Fe 1 fetch value of FB1 

: TMP and write to display as temperature 
value 

:L FB 1 when temp. < 110°C, switch on heater 
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'L KB 160 :JU 
<B END 
7S A 0.0 : GOON 
: :PRT “OVEN OKAY” 
:L FB 1 when temp. > 130°C, switch off heater : END 
:L KB 180 :PE 
>B 


7R QO @.0 
POS 64 cursor in 2nd display line 


7L FB 1 
:L KB 200 


:JC 
GOON: 
:PRT “OVEN ALARM!” 


else, display this text 


Further programming examples may be found in the subdi- 
rectory PLC87,EXAMPLE on the project diskette, order num- 


ber 986026-1. 


when temp. <150°C, jump to GOON 


show this alarm text when 


temp. > 150°C 


Glossary 


ACCU 

The PLC87(A) board has two accu- 
mulators (ACCU1 and ACCU2) with a 
width of 8 bits. They are essential for 
logic byte combinations, for byte com- 
parisons, for simple calculations and 
for shift operations. The ACCUs obtain 
their contents from load (L) com- 
mands. Before a byte is loaded into 
ACCU1, the current contents of 
ACCUT are moved into ACCU2. An 
ACCU may be used to load variables 
or constants. The results of an opera- 
tion are returned to the ACCU and 
may be copied to a variable using a 
transfer (T) command. 


Analogue value processing 

When an 87C550 processor is used, 
the PLC87A is also capable of pro- 
cessing analogue input values. The 
PLC system then offers six analogue 
inputs (AEQ-AE5). The measurement 
range is from 0 to 5 V. At a resolution 
of 8 bits, that corresponds to a binary 
range of 0 to 255. 

Each of the PLC87A inputs may also 
function as a digital input. When the 
input voltage exceeds 2.7 V, the asso- 
ciated bit in input byte 0 is set to 1. 
When the value is smaller, the bit 
remains at 0. 


BCR 

The BCR (bit combination result) is 
the result of logic combining of two bit 
parameters, and is recreated as fol- 
lows after each combination: 

[BCR] = [BCR(old) combined with 
bit parameter] 

The current BCR is stored in a mem- 
ory cell and may be copied to certain 
bit parameters with the aid of assign- 
ment commands. 


A fT. dad 
? AN I 0.0 
t = @Q 0.0 
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The BCR may also be affected by 
timers, counters and comparisons. 
The result of logic combinations 
(BCR) may be ‘noted’ using a flag, 
which can be interrogated later. Simi- 
larly, results from byte assignments 
may be read from the ACCU. There 
exists a causal relation between bit 
parameters and byte variables, and 
the programmer may exploit this rela- 
tion. The bit parameters are a subset 
of byte variables, which, in turn, are a 
subset of word variables. 

FWO = FBO & FB1 = F0.0 to F1.7 


Bit parameters 

Valid bit parameters are 

I inputs 0.0 —- 1.7 
8 system flag1.4 

Cc counters 0-7 

Q outputs 0.0 — 1.7 
Fr flags 0.0 — 15.7 
T timer o-~ 15 
Brackets 


Brackets allow bit combinations to be 
nested up to three levels deep. Make 
sure you have a closing bracket to 
match every opening bracket. 

As opposed to Simatic-S5 conven- 
tions, logic OR-ing of two blocks is not 
allowed without the use of brackets. 


Byte variables 

These are the parameters of byte 
operations, logic combinations, com- 
parisons or storage of values. 

Valid variables are 


IB input bytes 0 and 1 
QB output bytes QO and 1 
FB flag bytes 0-15 
FW flag words o-14 
Cc counters o-7 


PR polling register 


Constants 
Constants allow ACCUs or variables to 
be loaded with fixed values (con- 


a ~ 


(989966-2) 
stants). Valid constants are: 
KB byte constant (0-255) 
KW word constant (0- 65535) 


KT timer constant (0-255, 1-3) 
KC counter constant (O -255) 


Counters 

There are eight counters available (0- 
7), each capable of taking on values 
up to 255. No overflow is produced. 


cu c x count up on pos. 
edge of BCR 

cp Cc x count down on pos. 
edge of BCR 

R € « reset (sets count 
to 0 when BCR=1) 

&§ ¢C « set (load ACCUL 
into counter when 
BCR=1) 

E ¢€ interrogate counter 
(fetch value, move 
to ACCU1) 

a © « check for > 0 (when 


count > 0 then 
BCR=1) 


The highest count rate depends on 
the program cycle time. 


Flasher 
The system has available a flasher, S 
1.4 (see bit parameters), which oper- 
ates at a rate of 1 Hz. Its state may be 
interrogated by means of a logic com- 
bination. 


Jumps 

When the CL interpreter encounters a 
jump command, program execution 
continues at the CL line before the 
jump label, provided the jump condi- 
tion is fulfilled. There are two types of 
jump: 


JU unconditional jump to label 
Jc conditional jump if BCR=1 


The label is entered in the right-hand 
column of the CL, and is defined by a 
‘#’ followed by four characters. 
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PLC87(A) vs. Simatic-S5 

As already mentioned, the instruction 
set of the PLC87(A) is based on that 
of a Siemens Simatic—S5 system, It is 
not fully compatible with the S65! 
Because the PLC87(A) has accumu- 
Jators with a width of just 8 bits, and 
no modules, a number of commands 
have been simplified to some extent. 
The essential differences with the S5 
instruction set are: 


7. comparisons use ...B instead of ...F; 
2. shift operations use SLB, SRB 
instead of SLW, SRW; 

3. different method of 

addressing; 

4, program end has to be marked with 
PE; 

5, subroutines are placed at the end 
of the main program, they are called 
with UPA, UPC and closed off with 
RET; 

6. BE is used to separate the main 
program from subroutines; 

7.analogue inputs may be read 
directly 

8. as opposed to a Simatic system, the 
PLC87(A) recognises commands 
for LCD control and for the polling 
register (PR). 


indirect 


The butk of the commands is however 
identical, and that should enable you 
to teach yourself PLC programming 
using any of the vast number of 
courses and manuals covering the 
Simatic S5 standard. 

When using jumps and subroutine 
calls, you should make sure that the 
jump label occurs only once in the 
program. The CL may contain up to 
64 labels, no matter if simple jump 
labels or subroutine labels. Further- 
more, subroutines may only begin 
after a BE command. 


Programming errors 

The following errors typically cause 

the PLC87(A) system to crash. Recov- 

ering from a system crash is only pos- 

sible by removing the EEPROM and 

inserting it again. 

JU, JC used to branch to subroutine 

label 

1. UPA, UPC used to branch to jump 
label; 

2. Multiple use of flags 

3, Failure to use RET to close off sub- 
routine; 

4. Subroutine before a BE; 

5. No BE before program end and the 
first subroutine; 

6. Jumps from one subroutine into 
another; 

7. Nesting of subroutines; 

8, Too many opening brackets; 

9. Failure to complement opening 
bracket with closing bracket. 


Safety 
According to various standards for 
industrial safety, errors in automated 
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equipment may not cause a risk to the 
intrinsic safety of persons, machines 
or goods. Equipment parts relevant to 
any aspect of intrinsic safety should 
be implemented in hardware (i.e., tra- 
ditional circuit technology like relays 
and protective devices). An ‘emer- 
gency-off’ switch has to be imple- 
mented in hardware. With system reli- 
ability in mind, limit switches and other 
actuators should be connected to the 
PLC87(A) in the same way as to its 
hardware equivalent. For example, the 
‘off switch of a motor has to be wired 
and programmed as a _ normally- 
closed contact: 


AN I 0.3 switch: motor-off 
R @Q 0.5 stop motor 


Temperature measurement 

The ADJ command is available for 
temperature measurement using the 
AD22100K sensor from Analog 
Devices (see Datasheets, October 
1998 issue). A temperature range of 
-—50 °C to +150 °C then corresponds 
to an output voltage of 0.25 V to 
4.75 V. The contents of ACCUT7 is 
automatically adjusted to give ‘0’ at a 
temperature of —50 °C, ‘50’ at 0 °C, 
and ‘200’ at the maximum tempera- 
ture, 150 °C, 

The command TMP causes the mea- 
sured temperature to be shown on the 
LC display at the cursor position, or 
the position set up by the POS com- 
mand. 


Subroutines 

When the CL interpreter encounters a 
subroutine call, the program is con- 
tinued at the CL line before the sub- 
routine label, provided the call condi- 
tion is fulfilled. There are two types of 
subroutine call: ; 


UPA unconditional call 
upc conditional call (BCR=1) 


The subroutine should be closed off 
with an RET command to enable the 
interpreter to continue executing the 
CL at the line following the subroutine 
call. A BE command must be inserted 
between the main program and the 
first subroutine. 

Subroutines may be called as often as 
you like. They may not, however, be 
nested or call themselves. 


Timers 

The PLC87(A) command interpreter 
offers 16 timers (0-15), each having 
4 user-selectable functions. 


SD start with on-delay 

SF start with off-delay 
SP start as pulse 

SE start as extended pulse 


Before a timer may be started, a time 
constant has to be loaded into the 
ACCU. The value should be in the 
range 1-255 (in ACCUT), while the 
timebase goes to ACCU2 and takes a 
value of 1, 20r3for0.1s,1sor10s 
respectively, in the format XX.Y 


a ~ 


GENERAL INTEREST 


ition circuits, that’s 
even better! Among 
e countless circuits 
that can be labelled 
electronic locks’ an 
obvious, preferred, 
position is held by 
ystems employing 
- *gmartcards’. 


Design by Patrick Gueulle 


This type of application is particularly 
well suited to programming into a 
microcontroller with on-board EEP- 
ROM (electrically erasable program- 
mable read-only memory) such as the 
PIC16C84, even if you content yourself 
with the limited possibilities of a sim- 
ple programming language like BASIC. 


LEARN-AS-YOU 
PROGRAM 

The essential point of a Smartcard-con- 
trolled lock is simply the sheer infinite 
number of possible codes. 

A simple (expired) payphone or 
loyalty card, for example, is identified 
by a unique ‘reference number’ which 
is easy to read into a memory but 
almost impossible to modify. 

Such a 96-bit identifier word allows 
nearly 80 trillion (million million mil- 
lion) different card numbers to be 
issued. 

To exploit this almost inexhaustible 
stock of ‘keys’ represented by dispos- 
able chipcards, it is sufficient to design 
a reader unit capable of memorising 
the ‘images’ (electronic contents) of 
one or (better) several expired smart- 
cards, and then preferably cards you 


martcard-operated | 
code lock 


actually want to re-use. 
Having passed this ‘learning’ phase, 
the card reader may well control, say, a 
relay if and only if you insert one of the 
smartcards the reader has been 
‘trained’ to recognize as far as the elec- 
tronic content is concerned. 
Alternatively, you may want to con- 
sider ‘personalizing’ certain cards hav- 
ing one and the same ‘ID’, and origi- 
nally intended for applications not 
related to telephones, for example, 
GSMs, car-wash cards (Mobil and BP), 
parking cards, loyalty cards, satellite-TV 
cards, etc, An expired cat-wash card 
originally worth 24 units, for example, 
still contains 136 bits reading ‘0’, which 
are easily and individually set to ‘1’ 
with the aid of a chipcard reader/pro- 
grammer like the one described in Elek- 
tor Electronics September 1997. 
Although the most obvious choice is 
to use expired smartcards, an alterna- 
tive is to order new (blank) cards in any 
quantity you want, from suppliers like 
Elea (France, type number ELEA100), 
or Crownhill Associates in the UK (see 
their advertisement elsewhere in this 


magazine). 
As far as the author has been able to 
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find out, these 256-bit 
cards are not really 
blank, though, because 
they contain a ‘lot’ 
number in the memory are reserved 
for the first 96 bits. The next 160 bits 
are, however, at logic 0, and may be 
freely changed to logic 1s. 

Depending on the application(s) 
you have in mind, the electronic lock 
will either recognize one or two cards 
that can not be forged, or, by contrast, 
any number of identical cards that may, 
under certain conditions, be duplicated. 


A PIC16C84 
PROGRAMMED IN 
BASIC! 

The simplicity of the circuit diagram 
shown in Figure 1 may come as a sur- 
prise given the relative complexity of 
the functions it is designed to carry 
out. 

Actually, that is because the micro- 
controller used, a PIC16C84, contains 
almost everything we need; to begin 
with, a data EEPROM with a size of 
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64 bytes. 

This non-volatile memory is capa- 
ble of recording two ‘card images’ of 
256 bits each. These images may qui- 
etly remain in the PIC EEPROM for 
more than ten years, or be modified as 
many times as you like. 

Because the circuit does not con- 
sume any significant current unless a 
card is inserted into the connector, it 
may operate from a simple 9-volt bat- 
tery, although there is, of course, no 
objection against powering it from a 
mains adaptor or a rechargeable bat- 
tery (for example, that of an alarm sys- 
tem). 

Whatever power source is used, a 
type 78L05 voltage regulator is used to 
supply the PIC with its 5-volt supply 


‘DUAL smart card lock with PIC16F84 


‘copyright 
symbol f = 
symbol g = 
symbol e = 
symbol r = 


(c) 1998 Patrick GUEULLE 
BO 
Bl 
B2 
B3 


symbol BLINK = B4 


symbol h = 


B5 


DIRS = %11100110 
PINS = %00000010 


high 7 
high 6 
low 6 
low 7 
high 6 
low 6 


if PIN3 = 
if PIN3 = 


Kh 
° 
tn] 
Ph 
i] 
o 


@ 

i] 

o 
+ + Il 

i] 


high 6 
low 6 
next g 


0 then learn 
1 then check 


to 31 


h = 32 * PINO 


h=h+t+ef 
write h,e 
next f 

PINS = 0 


BLINK = 50 


goto led 
check: 
for 
e= 


f= 0 
0 
for g 
e 
e 


ife<>r 
goto cont 
other: 


h = £ + 32 


read h,r 

ife<>r 
cont: 

next f 


to 31 


then other 


then error 


PINS = %00000110 
goto forever 


error: 
PINS = 0 


BLINK = 255 


goto led 
led: 

for f = 0 
high 1 


to 10 


pause BLINK 


low 1 


pause BLINK 


next f 
forever: 


goto forever 


voltage, while a transistor allows the 
relay coil to operate at a sufficiently 
high coil voltage. 

It will be clear at this point that the 
wonderful simplicity of the circuit is 
due to an invisible program executed 
by the PIC microcontroller. 

Tt may come as surprise to you that 
the control program was written in 
BASIC, or PBASIC to be precise, a 
‘dialect’ originally developed by Paral- 
lax Inc. for its BASIC Stamp modules. 

Although it would be easy to down- 
load the program shown in Figure 2 
into a BASIC Stamp 1 wired up to a 
Smartcard reader unit, we could not 
resist the temptation of an alternative 
solution which looks poised to become 
a buzz-word: compiling. 

Several PBASIC compilers for the 
PIC microcontroller are available from 
reputed companies like Forest Elec- 
tronic Developments and Micro Engi- 
neering Labs, but they may also be 
found in the public domain. 

Whereas the most efficient of these 
compilers produce object code which 
is competitive to what can be produced 
with an assembler program, the sim- 
plest of them are no more than ‘inter- 
preters’. 

That is not to say that the term 
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‘interpreter’ is inappropriate here 
because the BASIC program is actually 
stored in memory in the form of 
‘tokens’ (a couple of bytes per instruc- 
tion), which a resident piece of soft- 
ware starts to ‘interpret’ one by one. 
However, this process is usually called 
‘tokenising’ instead of ‘interpreting’. 

The compiler we employed for the 
present project at the same time loads 
this ‘firmware’ and the ‘tokenised’ 
BASIC into an ordinary PIC16F84 of 
which about three quarters of the avail- 
able program memory is occupied. 

By contrast, the BASIC Stamp 1 
comes with its interpreter mask-pro- 
grammed into the (read-protected) 
EPROM on board an OTP (one-time 
programmable) PIC16C56, while the 
BASIC ‘tokens’ are stored in a separate 
EEPROM type 93LC56. 

Whatever method is used, 256 bytes 
are available for the application pro- 
gram. Strange as it may sound, that is 
both a lot and very little to go on, 
mainly, because the tokenised BASIC is 
very compact. 

For sure, the approach using the 


P-1SaQse 


BASIC Stamp is the most practical dur- 
ing the development phase. On the 
other hand, the use of empty PICs and 
a compiler is cheaper once the system 
software and hardware have passed 
the debugging phase. 

The fact that a compiler could be 
used which is compatible both with the 
BASIC Stamp and the PICI6F84 was a 
great help when it came to writing our 
program, particularly at the level of 
accessing the EEPROM, a function 
which is a bit difficult to implement in 
assembly language. 

It is universally acknowledged that 
most ‘interpreted’ BASIC runs at snail's 
pace. Here, however, that turned out to 
be an advantage because delay loops 
are then not required! 

The PIC is clocked at about 2 MHz 
by a simple RC network, and requires 
less than a second to read 256 bytes 
from any synchronous chipcard using 
the German or French protocols for 
data/command exchange. 

A reset facility is provided to make 
the circuit compatible with payphone 
cards from almost any country. 


980061-1 
(C) ELEKTOR 
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PRACTICAL 
REALISATION 

If you construct an electronic code 
lock, based on whatever circuit princi- 
ples, you should observe a minimum 
number of elementary security mea- 
sures, 

It would have been (too) easy to 
throw all components that make up 
the circuit on the same board as the 
inevitable chipcard connector, and pre- 
scribe the use of SMA (surface-mount 
assembly) components to keep the size 
of the board within reason. 

We know several examples of ‘pro- 
fessional’ equipment from reputable 
manufacturers, having the above-men- 
tioned deplorable and over-simplistic 
construction. 

In a number of cases, it was suffi- 
cient to remove just two screws to get 
access to two wires which, when short- 
circuited, open the locks... 

The printed circuit board of which 
the design (artwork) is shown in Fig- 
ure 3 has been designed to facilitate fit- 
ting the electronics in a safe place, that 
is, inside a building or room to be pro- 
tected (for example, on the inside of a 
door). 

The only part which is accessible 
from the outside is the card connector, 
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whose ISO and AFNOR contacts may 
be wired in parallel if you want the sys- 
tem to be able to process both card 
types (the AFNOR pin arrangement is 
now obsolete even in France). 

(Dotted) components R8/T2 are pro- 
vided to allow card connectors with 
either a normally-open (NO) or nor- 
mally-closed (NC) contact to be used. 

In the first case, you do not fit 
R8/T2, and install a short wire linking 
the base and collector pads reserved 
for this transistor. This link is shown as 
a dotted line. If, on the other hand, you 
have an NC-style connector available, 
you have to install these two parts, and 
no wire link, 

As illustrated in Figure 3, a 10-way 
flateable is used to connect the card 
reader to the circuit. This cable is fitted 
with an IDC (insulation displacement 
connector) socket to be plugged on to 
the 10-way pinheader on the PCB. 

Considering the (purposely- 


reduced) speed of the signals 
exchanged with the Smartcard 


(approx. 500 Hz), cable lengths of up to 
50 cm may be used without problems. 

A robust 4-way PCB mount termi- 
nal block allows the dc power supply 
(9 to 15 volts) to be connected to the 
board (K1), as well as the load to be 


switched on and off by the relay con- 
tact (K2). This contact is only closed 
when the ‘right’ card is detected in the 
card reader. 

The LED has to be mounted so that 
it is only visible when the system is 
being set up, because its very function 
is to inform you of the correct execu- 
tion of each of the steps in the process. 

Two jumpers, finally, allow you to 
select between the two available 
modes of operation: ‘learn’ or ‘normal’ 
use (1 / 2). It is not necessary or even 
desirable (for obvious reasons) to pro- 
vide access to these jumpers for any 
purpose other than the process of 
‘teaching’ the system to recognize new 
cards. 

The programmed PIC for this pro- 
ject is available through our Readers 
Services under order code 986511-1, It 
should not be installed in its socket 
before you have checked your con- 
struction and verified the presence of 
the correct voltages at several points in 
the circuit. 


PRACTICAL USE 
Easy to build, the electronic code lock 
is even easier to use. 

As a matter of course, you should 
start by ‘teaching’ the PIC to recognize 


—-al 
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a certain Smartcard. To do so, install JP1 
to select ‘LEARN’ mode. That effectively 
pulls the RB3 port line of the PIC (pin 9) 
to ground, Next, insert the Smartcard or 
payphone card into the reader. 

The LED should light up, indicating 
that the circuit is being powered. After 
about one second the LED should start 
to flash rapidly. This ‘eye-winking’ 
indicates that the card image (elec- 
tronic contents) has been transferred to 
EEPROM, and that it remains there 
until another card is inserted, even if 
you turn off the power supply and 
leave it off for months. 

Having supplied this signal, the 
LED indicator goes out, and you can 
safely withdraw the card, which from 
then on is promoted to ‘master key’. 

Now remove the ‘LEARN’ jumper 
and insert your Smartcard again. The 
LED indicator should light, and the 
relay should be energised the next sec- 
ond or so. It remains energised and the 
LED remains on, as long as the card is 
in the connector. 

Remove the card and try another. 
Unless this one has exactly the same 
contents as the ‘master key’, the LED 
should flash slowly, and then go out. 
Of course, the relay should not be 
energised! 

The above process may be repeated 
after changing the jumper in position 
‘1 /2', which enables the electronic lock 
to be ‘taught’ to recognize a second 
card, 

In case you want the lock to recog- 
nize just one card, you have to present 
it to the system for both positions of 
the ‘1/2’ jumper. This is done to avoid 
the system security being weakened by 
leaving one half of the EEPROM in an 
undefined state. 


ENCODE YOUR OWN 
CARD SERIES 

Although the ability of the system to 
recognize two different Smartcards will 
be sufficient for many applications, 
there will be cases in which many 
more users need to be authorized to 
open one and the same door or lock 
(as, for instance, in a laboratory with 
controlled access, a club or a block of 
apartments). 

You then turn to cards whose con- 
tents was originally the same, within 
the same series, and you complete the 
encoding by a couple of freely chosen 
bits. 

As an example, let’s use car-wash 


cards sold in France by BP or Mobil 
petrol stations. Once expired these 
cards are thrown away by the tens of 
thousands by their users. 

A Smartcard worth 24 units (cred- 
its), all used up, contains the following 
256 bits: 


1000 1000 1000 0000 0010 0000 0000 0010 
0011 1100 0111 0101 1000 0010 0010 0100 
1010 0001 0000 0000 0000 G000 0000 0001 
0000 0000 OO11 L111 112121 2411 1111 1111 
1100 0000 0000 0000 0000 G000 0000 9000 
0000 0000 0000 0000 0000 0000 0000 0000 
0000 0000 0000 0000 0000 G000 0000 0000 
0000 0000 0000 0000 0000 0000 0000 0000 


In the first three lines we find the name 
of the card manufacturer, which can 
not be modified. The name string is 
identical on all 24-unit cards issued up 
to now, but different from the one on 
12-unit cards, which, fortunately, are 
equally easy to obtain (in France). 

Next come 10 bits all reading ‘0’, fol- 
lowed by 24’1’s (these are the used-up 
credit units), and then 126 ‘0’s which 
are not used by the application. 

If you make the mistake of ‘teach- 
ing’ the electronic lock to recognize 
such a card, then the door can be 
opened by anyone having an expired 
car-wash card originally = worth 
24 credit units! 

The obvious thing to do is of course 

to ‘personalise’ the card and so limit 
the number of authorized cards in 
accordance with the number of people 
(card users) who are authorized to 
open the lock. Cards may be ‘person- 
alised’ quite easily using the software 
utility ‘ELEKT1G’ and the associated 
Smartcard Reader/Writer, both as 
described in the September 1997 issue 
of Elektor Electronics. 
The following example goes to show 
how to change any number of the 136 
‘0's on the card into logic ‘1’, simply by 
pressing the ‘+’ key on the PC key- 
board when the cursor is on top of the 
desired bit, after the card data have 
been read. 


read next bit 
(auto-repeat) 
+ key: write | 

(at current location) 
ESCape key: quit 


Space bar: 


1000 1000 1000 0000 0010 0000 O000 0010 
0011 1100 0111 0101 1000 0010 0010 0100 
1010 0001 0000 0000 0000 0000 C000 0001 


0011 Q000 0012 1212 14111 11121 1111 1111 
1100 0000 0000 0000 0000 0000 0000 0000 
0000 0000 1010 0000 0000 0000 0000 Oo00 
6000 0000 0101 0000 0000 0000 0000 o000 
0000 0000 0000 0000 0000 0000 0000 o000 


WARNING: Switch the Vpp off! 


For the other authorized cards you fol- 
low exactly the same procedure, and 
you use on of these cards to ‘teach’ the 
electronic lock the code by which the 
door is opened. 

The same procedure may be 
applied with ‘blank’ (new) cards, pro- 
vided they are of the GPM256 type or 
similar (256 bits of EEPROM) — ask 
your supplier. 

Whether the card is new or expired, 
only the first 96 bits have already been 
personalised (by the manufacturer), 
the remaining 160 being at 0 and freely 
programmable by yourself. 

Here is an example of what may be 
found on a card picked from an actual 
batch: 


0000 0000 1000 0000 0000 0000 0000 c000 
0100 1011 0000 0000 0000 0000 0000 o000 
1111 1111 1111 6000 0000 1111 1211 1111 
0000 0000 0000 0000 0000 0000 0000 da00 
0000 0000 0000 0000 0000 0000 0000 0000 
0000 0000 0000 0000 0000 0000 0000 0000 
0000 0000 0000 0000 9000 0000 0000 0000 
0000 0000 0000 0000 0000 0000 0000 0000 


The buyer of a batch of these cards is 
totally free to employ ELEKTIG to 
write logic 1's into any location(s) in 
the last five lines, as illustrated below: 


0000 0000 1000 0000 0000 0000 0000 0000 
0100 1011 0000 0000 0000 0000 9000 0000 
1111 1111 1111 0000 0000 1111 1111 1111 
1111 1111 6000 0000 0000 0000 0000 0001 
0000 0000 0000 0000 0000 0000 0000 0000 
0000 0000 0000 1100 0011 0000 0000 oO00 
1000 0000 6000 0000 0000 0000 0000 co00 
0000 0000 GO00 OO00 0000 0000 1110 0010 


WARNING: Switch the Vpp off! 


Of course, you have to be aware of the 
fact that such a card may be copied, 
but only on to a card with the same 96- 
bit manufacturer-ID, which means that 
it has to be from the same batch bought 
from the same manufacturer. That seri- 
ously limits the possibilities of cards 
being forged! 
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PC control for 
MiniDisc player 


2am up track titles from your PC 


Sure, it did take some 
time, but it is fair to 
~ gay that Sony’s Mini- 
: Disc has finally 
achieved market 
acceptance. The cir- 
cuit presented in this 
article enables a Mini- 
Disc deck to be con- 
trolled in a comfort- 
able way when it 
- comes to entering 
rack titles. By using a 
~ PC and some clever 
~ electronics, you can 
_ put track titles onto 
your shiny little discs. 


Specifications 


= For use with Sony MD decks types MDS-JE500 and later 
« Transmitter range: several metres 

= Up to 99 track titles 

= Up to 2032 characters per MD 

= Suitable for any PC with a free RS232 port 

= Standard 9-pin RS232 connection 

<2 No special software required 

<> May be combined with a track-title database 

= Energy-saving design 

<= Powered by one 9-V battery 


MiniDisc (MD) audio systems are sold 
by the hundreds of thousands every 


have made it to general recognition 
and commercial success after a number 


Design by P Glatzel 


year in various countries in which this 
Elektor Electronics is published. After a 
slow start, the MD system appears to 


of years. Not surprisingly, several read- 
ers (mostly proud owners of MD 
decks) wrote to us with the request to 
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give some attention to the MiniDisc 
system. One frequently heard short- 
coming of the MD system, we learned, 
is that entering a track title list is cum- 
bersome. Although every MiniDisc 
has sufficient capacity for 256 tracks 
representing a total of 1,700 text char- 
acters, the process of actually entering 
the texts you want is very user 
unfriendly: lots of cursor and letter 
keys have to be pressed on the com- 
pact remote control before any mean- 
ingful text appears on the display. This 
text function is of special interest to 
music collectors. Tracks on old records 
(LPs), for example, can be efficiently 
filed together with the name of the 
album, the release number, name of 
the artist(s), etc. In most cases, the 
available space of 1,700 characters will 
be more than sufficient. A fine system, 
really, if only the process of entering 
texts was a little less awkward. 

In this day and age, with he prolif- 
eration of PCs, it must be possible to 
simplify the process of conveying a 
track title to a MiniDisc deck, and, 
from there on, to the little disc itself. 
The designer of the present circuit 
fully agrees with this opinion, and set 
out to combine the functionality of a 
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AT89C2051 


PC with the power of a small micro- 
controller. This has become possible 
ever since Sony, from their model 
MDS-JE500, started to incorporate soft- 
ware in their MD decks that allows 
texts to be read by an infra-red receiver 
and then copied on to a MiniDisc. The 
PC control for MiniDisk players dis- 
cussed in this article forms the link 
between a text file (document) written 
on your PC, and the infra-red ‘eye’ on 
the MD player. The system allows any 
PC to ‘beam’ up to 99 track titles to the 
MD deck, which writes them to a 
MiniDisc. If you are not sure if a par- 
ticular MD deck will be compatible 
with the present circuit, ask the sup- 
plier if it is suitable for use with the 
advanced MD Title Generator sup- 
plied by Sony. If it is, then the present 
circuit can be used also. 


THE CIRCUIT IN 
DETAIL 

The circuit diagram of the MD control is 
shown in Figure 1. The input is formed 
by connector K1, a 9-way serial port. 
The output is formed by an infra-red 
sender diode, D3. IC4, a 
MAX232, converts the 
signals on the serial 
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port from TTL to R5232 levels, and the 
other way around, The electrolytic 
capacitors around IC4 help the internal 
circuits in the MAX232 to adapt the 
various voltage levels. In this way, the 
internal charge pump enables a sym- 
metrical voltage to be derived from a 
direct voltage of +5 V. 

Although the circuit only uses the 
TxD, RxD and CTS signals on the 
S232 port, these are sufficient for reli- 
able data exchange between the MD 
control and the PC. The three logic sig- 
nals appear at TTL level on three pins 
of the microcontroller (P3.0, P3.1 and 
P3.2) type AT89C2051 from Atmel. 

The controller is an 8-bit machine 
whose instruction set is compatible 
with Intel’s MCS-51 instruction set. It 
has 128 bytes of RAM and 2 Kbytes of 
Flash memory. 

The circuit around the controller 
includes a standard crystal oscillator 
operating at 11.0592 MHz. 

The line marked ‘ACTIVE’ (P3.5) 
plays an important role because it is 
used to implement software control of 
the power supply. You actuate the cir- 
cuit by pressing switch 
51. The base of transis- 
tor T2 is then pulled to 
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ground via resistor R22, whereupon 
the power supply is activated. The 
microcontroller then receives its sup- 
ply voltage, and is initialised. Upon 
detecting that the ON line is active, the 
controller pulls the ‘ACTIVE’ line logic 
high, causing transistor T3 to be 
switched on. As a result, the power 
supply remains switched on even if 
you release $1. If the circuit has been 
inactive for some time, the microcon- 
troller makes the ‘ACTIVE’ line low 
again and so causes the whole circuit 
to be switched off. In this way, the bat- 
tery life is considerably extended. 
There is another benefit, namely that 
you can switch off the circuit by hold- 
ing S1 depressed for about 2 seconds. 


Incidentally, the circuit will only 
respond to this command if no com- 
munication activity is detected on the 
RS232 port. 

Although it may appear rather com- 
plex at first blush, the power supply is 
of a straightforward design. Transistor 
T2 is the actual on/off switch which 
conveys the applied direct voltage to 
ICI, at the command of S1 or T3. The 
output of IC1 supplies a stable direct 
voltage of 5 V. Diode D1 protects the 
circuit against accidental supply rever- 
sals. Although a 9-V battery is the pre- 
ferred power source, the circuit may 
also be powered by an inexpensive 
mains adaptor having an output volt- 
age between 9 V and 12 V. 


¥OLN3Ta (9) 
L-Z60086 


Seay 


ae 


Via its input pins 12 and 13, the 
microcontroller continuously monitors 
the levels of the stabilised and non-sta- 
bilised voltages. Actually, the voltages 
at these pins are scaled-down versions 
of the full supply levels. 

Two of the microcontroller’s output 
lines are used to control LEDs D5 and 
D6. As soon as an output drops low, 
the associated LED lights up. Further, 
two port lines are in use to implement 
the communication with the EEPROM. 
Both lines (pins 16 and 17) simulate an 
PC bus, and are connected to the +5- 
V rail via a pull-up resistor. The EEP- 
ROM, a type 24C16, is used to buffer 
the text which is eventually stored on 
the MiniDisc. After all, the whole point 
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of the circuit is to be 
able to ‘beam’ data from 
the PC to the MiniDise player. 

The transmitting of data is accom- 
plished by the transmitter stage built 
around transistor Tl and IR sender 
diode D3. This stage effectively con- 
verts pulses received from the micro- 
controller into infra-red light signals 
the MD is capable of detecting. 


CONSTRUCTION: 
SIMPLE AND COMPACT 
A circuit like this simply demands a 
compact construction, and we believe 
we have been successful in this respect. 
As you can see from the photographs 
in this article, the size of our prototype 
may be compared to that of a regular 
remote control. The PCB has been 
designed such that a standard case 
from Heddic is easily adapted for a 
perfect fit. The board, the battery, the 
sender diode, the control push-button, 
the serial connection and the two LEDs 
form a compact unit. 

The copper track layout and com- 
ponent overlay of the circuit board may 
be found in Figure 2. The board is sin- 
gle-sided, contains one wire link, and 
accommodates all components. Before 
you start soldering, it is useful to first 
determine the exact locations of the 
holes for K1 and $1. The actual solder- 
ing work, we reckon, is not likely to 
cause problems. Once the circuit is fully 
built up, it may be fitted into the enclo- 
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sure, and the bat- 
tery may be con- 
nected. The unit is then ready for use. 


ENTER THE PC 

As already mentioned, the present con- 
trol allows comfortable programming 
of track titles on a MiniDisc. In princi- 
ple, there are two ways of storing your 
data in the EEPROM. Using a simple 
terminal program which may be found 
on almost any PC, laptop PC, organiser 
or, indeed, any other computer system, 
it is possible to ‘get in touch’ with the 
circuit. In all cases, select the following 
serial port settings: 


Baudrate: 9600 
No. of bits: 8 
Parity: none 
Stop bits: 1 
Handshaking: hardware 


After switching on the circuit (press the 
push-button briefly) the red LED lights 
up, and the circuit identifies itself by 
producing this message on the PC 
screen: 


MD programmer V1.1 

Title input help for Sony MD-Players 
By Peter Glatzel (February 98) 
Copyright Elektor 1998-09-08 
Equipment types JE500...JE700 


If this message appears, the circuit and 


the PC link are fully functional, and the 
MD control is waiting for a command. 


In command input mode, the follow- 
ing commands are recognised: 


d dump EEPROM contents to PC via 
RS232 port 

¢ clear EEPROM contents 

m manual input mode 

el select character set of equipment 
from MDS-JE series 

e2 select character set of equipment 
from SAJ series. 


If you have an MD player from the SAJ 
series it is essential to be able to switch 
between the two equipment families 
supported by the control. In all other 
cases, the correct character set has 
already been selected for you. 

To begin with, select ‘m’ via your 
terminal. Next, enter the MD title and 
the track titles: 


OO MD title (CR+LF) 
Ol Title of track no. 1 (CR+LF) 


99 Title of track no. 99 (CR+LF) 
# End of input file 


In this simple way, all data may be 
entered. Apart from letters and num- 
bers, the following characters are also 
acceptable: 

V$%k'()* +,-./,<=>?@_- 

The ‘hash’ character (#) at the end of 
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each file is not transmitted to the MD 
player. Instead, it is used by the circuit 
to detect the end of the transmission. 
As soon as the # character is received, 
the circuit is switched off. 

The dump (‘da’) command allows 
the EEPROM contents to be evaluated. 
If everything is all right so far, you may 
proceed to the next step. 

The circuit is disconnected from the 
PC, and the IR sender LED is pointed 
at the MD deck — the system is ready 
to start transmitting data. At this point, 
it is essential to have a MiniDisc in the 
player, and that the player is ready for 
text entry. Press the button on the MD 
control, whereupon the yellow LED 
lights. The titles you programmed 
should appear one by one on the MD 
player’s text display. After the MD 
player has updated the TOC (table of 
contents), the disc contains the new 
title list. 

While testing and developing this cir- 
cuit, it was discovered that some MD play- 
ers insist on 3-digit track numbers. In that 
case, put an extra 0 before each track num- 
ber. You can find out if your player requires 
the third digtt by reading back the MiniDisc 
TOC — the first character of the track title 
is then missing. 


The other method of programming the 
MD player is even user-friendlier. All 
you have to do is use a word processor 
to create an ASCII file which contains 
all track titles preceded by their track 
numbers. The final file will be identical 
to the text transmitted line-by-line in 
command input mode as discussed 
above. In ASCII mode, too, the end of 
your file is indicated by a ‘#’ character. 
Next, give the file a name, save it on 
hard disk, and start the terminal pro- 
gram. Make sure the program is prop- 
erly configured, and select the option 
‘transmit file’. After entering the 
desired file name, the file is actually 
transmitted and stored in the EEP- 
ROM on the MD control board. Of 
course, this requires the control board 
to be switched on, and the yellow LED 
should light. ‘Beaming’ the file from 
the MD control to the MD player is 
then identical to the process outlined 

above. 
(9B0092-1) 


Note: 

readers wishing to know more about the 
many possibilities of the MiniDisc system 
are advised to visit the a special Internet 
site dedicated entirely to the MiniDisc. 
The address is 
http://www.czechin.com/minidisc. On 
this site, extensive information is avail- 
able on various technical aspects of the 
MiniDisc system, including track-title 
entry using a PC. 
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About terminal programs 


Setting up a terminal (‘com- 
munication’) program may 
present some unexpected 
difficulties. Here, we pro- 
vide some guidance to 
configuring the standard 
terminal program. In Win- 
dows 95/98, go to Acces- 
sories and launch HyperT- 
erminal.exe. Enter a name 
for the new connection, 
say, ‘MD Programmer’. 
Then, you are ready to 
make a configuration file for 
this connection. 

In the first window, you 
select the serial port you 
are using — in the exam- 
ple, COM2 is used. Obvi- 
ously, the port you want to 
use has to be available! 
Click on OK. 


In the second window (Port 
Seitings) the essential set- 
ting is ‘9600’ for the bit rate. 


Next, go to File — Proper- 
ties, select ‘ASCII Setup’, 
and activate the option 
‘append line feeds to 
incoming line ends’. Click 
on OK and close off the 
configuration. 


The next time you want to 
use HyperTerminal to com- 
municate with the MD Con- 
trol, all you have to do is 
double-click on ‘MD pro- 
grammer.ht’ to enable the 
right configuration. 


In Windows 3.1, things are 
a bit more complicated, 
mainly because the termi- 
nal program that comes 
with this operating system 


Phone Number 


COM2 Properties 


works in a slightly different way. In the Settings menu, you use the ‘Communica- 
tions’ option to configure the serial port. Apparently, the handshaking used in the Win 
3.1 Terminal program is different from HyperTerminal, because Terminal is not capa- 
ble of error-free file transmission with ‘hardware handshaking’ enabled. The only 
way to solve this problem is to go back to the Settings menu, select Text Transfers, 
and pick ‘character at a time’ for the flow control type. This results in characters 
being sent one by one to the ‘remote’ station, with 100-ms pauses. Obviously, this 
communication is much slower than with HyperTerminal, but there you are. 
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A small experimental board for the Atmel! AT90S1200 8-bit RISC 
processor was already presented in the October issue, together with 
the necessary application data. In this, the second and last part of 
the article, we present sample programs, including a frequency 
divider, a numerically-controlled oscillator (NCO) and programs for 
measuring time and frequency. 


boy Lor Mi. COorasrricam 


AVR-RISC evaluation 


system 


Due to its high clock frequency (up to 
16 MHz) and its RISC structure, which 
allows it fo execute most instructions 
within one clock cycle, the very inex- 
pensive Atmel AVR controller can take 
on applications that would normally 
require the use of more costly pro- 
grammable logic devices. The easiest 
way to learn how fo program such 
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applications is to study easily imple- 
mented sample programs. The pro- 
gram for the first application example, 
a simple signal-pattern generator, was 
included in the first part of this article. 
The step from a this simple pattern 
generator to a frequency divider is not 
very great. You can construct simple 
‘wait loops’ for relatively large divider 
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ratios. For example, the 12 MHz clock 
must be divided by 625 to produce 
the well-known serial bit rate of 19200 
pulses per second. A divider based on 
a microcontroller has the great advan- 
tage that if is often more flexible than 
a classical design. The program listing 
shown in Figure 6 (SCDIV625.ASM), for 
example, not only divides by 625, but 


PC Topics 


also generates non-overlapping puls- 
es as illustrated in Figure 7. By varying 
the parameters nl] and n2, you can 
adjust the divider ratio and the duty 
cycle of the outpufs over a wide 
range. 


Fancy frequencies: 
the NCO 


With a frequency divider, it is only pos- 
sible to simply divide a clock rate (as 
the name suggests). But what can you 
do if you need to derive a frequency 
of 77.5 kHz from a 12 MHz clock? (Let's 
assume that the derived frequency 
need not be exactly 77.5 kHz, so that 
for example an error of 0.005 Hz is 
allowed — this represents an error of 
less than 1 ppm!) 

Modern clock synthesizers employ DDS 
(direct digital synthesis) oscillators for 
this purpose (see Figure 8). A DDS 
oscillator consists of the actual numer- 
ically controlled oscillator (NCO), a 
sine look-up table and a D/A convert- 
er. As can be seen from the figure, the 
NCO itself is built using a relatively 
wide adder (often 32 bits). This func- 
tion can be emulated by the micro- 
controller, using the program listing 
shown in Figure 9. One cycle of the 
DDS oscillator lasts for eight controller 
clock cycles. With a clock rate of 12 
MHz, the clock rate of the NCO is thus 
12+8 = 1.5 MHz. The wiath of the NCO 
is 29 bits. To generate a clock with a 
frequency of 77,500 Hz, the value of 
the repeatedly added constant term 
must be chosen as follows: 


(77500 Hz)-(22%)=(1.5 MHz) = 
554766627738330 = 1A740DA (hex). 


This is exactly what the sample pro- 
gram does, with the result that a 77.5 
kHz clock appears at the Port B, bit 4 
output (pin 16). The error is less than 
(1.5 MHz)+(22%) = 0.00279... Hz - 
which is quite negligible. A simple D/A 
converter as shown in Figure 10 also 
allows a sawtooth waveform to be 
generated from the NCO. 

You can see that a microcontroller that 
costs only a few pounds can be used 
to generate frequencies up to 100 kHz 
with an error of 0.003 Hz or less. A ver- 
sion of the sample program that allows 
you to select the value of the frequen- 
cy from the PC via the R$232 interface 
is included on the — diskette 
(NCO2.ASM). 

There are many varied applications for 
such an NCO, It can for example be 
used in a PLL circuit as a ‘non-integer’ 
divider that reduces the controlled fre- 
quency to the rate of the reference 
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frequency (see Figure 114), or it can 
be used directly as a reference oscil- 
lator with very fine adjustment capa- 
bility (see Figure 11b). 


Time measurements 


The next application is measuring the 
duration of the HI interval of a logic 
signal. This is accomplished by first 
waiting in a program loop (labeled 
waitL) until the signal goes LO and then 
waiting again until it goes HI (in the 
loop labeled waitH). While the signal is 
HI, the program stays in a counter loop 
(labeled m1) that keeps track of how 
many times the loop has been execut- 
ed and senses whether the signal is still 
HI, As soon as if goes LO, the loop is 
exited and the result is output (see the 
program listing in Figure 12). 


Listing figure 6 


sequ nl #2 
.equ n2 =203._ 


ldi rl6,Sff_ 
out DDRB,r16_ 


LOOP: cbi 


sbi PORTB,1 }°[2] 


ldi rl6;nl <3 
wtl:: dec rl6 
“brne wtl : i 
cbi PORTB,1 7 
sbi ©. PORTB,O - 
ae f-2% “rl6;n2.. 
wt2: dec 1G Le 
SEE 2 SS pyner eS 
epmp LOOP ss 


> set output B 


PORTB,O. ; [2]. fist bit0 goes Low. 


The inner counting loop consists of 6 
cycles and thus takes 0.5 pis with a 12 
MHz clock. This means that the pulse 
duration can be measured with a res- 
olution of 0.5 us. The loop counter is 3 
bytes wide (24 bits}, so it can count up 
to 224 = 16,777,216. Since 224-(0.5 tus) 
= 8s, this short program can measure 
times from 1 pis to 8 s with a resolution 
of 0.5 us. If you need to measure 
longer intervals, you only have to 
increase the width of the counter. This 
will slightly reduce the resolution, since 
the loop will take longer to execute, 
but that usually does not matter with 
long time intervals. The program 
XTMES1.ASM on the diskette includes 
both the actual measurement loop 
shown in Figure 12 and a function to 
output the result in normal decimal 
form via the RS232 interface, so that 
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Figure 6. Listing of the program for dividing by 625. 


CLK 
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Figure 7, Non-overlapping pulses, which are also generated by the program listed in 


Figure 6. 
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you can build a precision time-interval 
measurement device with serial data 
output using only a single IC. Figure 


Listing figure 9 


do 


.def dQ. =rl6 
def Ah ee Tes 
-def sda ee SELB > 
sdef 2 edB Seed gs 
-def neo0. =r25 
-def neol =r26-— 
»deft neo2° =r27- 
sdef. ..-nieo3.. Br28 
RESET: ldi 16, $££" 
out  DDRB,;rl6 
“Adi 0, SBA 3 
sic waz 
ldi di,$40 ee 
Idi d2,$A7 
“Adi d3,$01 
LOOP: add nco0, dod 
ade nceol,dl 
adc nco2,d2 
| adc nco3,d3- 
: 
andi n¢éo3,$01F 
out. PORTB, nco3 
ox jmp 


LOOP 


Figure 8. A NCO is fairly simple (at least in block-diagram form)... 


13 shows the complete schematic dia- 
gram. Thanks to its built-in logic, the 
AT90S1200 does not even need any 


; set output to totem-pole _ 


O1A740DA gives 77.5 kHz at 12 


XBL : 


7°29 bit nco summation ie 


3 {1] 5 MSB bits go out 
a AME: 
“pf [2] total 8 cycles 


Figure 9. ... and the program for the NCO function is just as simple. 
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Program assembly and 
device programming 


The assembler is started by typing: 
a <file name> 


To program the IC, enter ‘p’ togeth- 
er with a second letter, as follows: 

z to erase 

p fo program 

v to verify 


This applies equally well to the EEP- 
ROM (if used). 

The batch files are: 

a.bat (assembler) 

p.bat (programmer) 


The second of these must be modi- 
fied if a non-standard COM port is 
to be used (COM2 is the standard 
setting). 


A COM port other than COM2 can 
also be used with the Pascal pro- 
grams; the desired port is selected 
by typing: 

progname-COMx 


With the program V24COM.EXE, the 
baud rate is set to a standard value 
of 9600. 
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Figure 10. The circuitry needed to build a 
discrete D/A converter for the microcon- 
troller, 
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Figure 11. Using an NCO as a divider in a PLL (a) and as a reference frequency source [b). 


external circuitry to generate the reset 
signal. Truly, it would be difficult to con- 
struct a simpler device for measuring 
time intervals, and when you don't 
need it any more you can ‘recycle’ it 
as a frequency meter, as illustrated in 


the next example. 


Frequency measurements 


The AT90S1200 has an internal 8-bit 
counter that (with suitable program- 


Figure 12. Listing of the time-interval measurement program. 
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ming) can be clocked via Port D bit 4 
(pin 8). The external clock signal is sam- 
pled by the processor clock, so that 
the maximum clock rate for the 
counter is half the crystal frequency — 
which is still more than 5 MHz. The 
diskette includes a program 
(XFMES1,ASM) that uses this counter to 
implement a frequency counter. A pro- 
gram loop that executes in exactly 12 
million cycles (1 second) is used for this 
purpose. The internal counter runs for 
the duration of this loop, and a 16-bit 
software counter is incremented each 
time the internal counter overflows, so 
that a 24-bit result (8 + 16) is available 
at the end of the 1-second interval. This 
result is subsequently output via the ser- 
ial interface in decimal form. In this 
way, the circuit shown in the schematic 
of Figure 13 can be used to construct 
a simple frequency counter with serial 
data output and a resolution of 1 HZ for 
frequencies up to 5 MHz. 


Further possibilities 


Naturally, it is possible to do a lot more 
with the AT90S1200, in particular with 
its interrupt facilities and the built-in 
EEPROM, but that is outside the scope 
of this article. The AT90S1200 also has 
a big brother, called the 9051200, 
which unfortunately can be used at 
clock rates up fo only 8 MHz (instead 
of the originally announced 20 MHz). 
The 9081200 has an 8 kB program 
memory, a 512-byte EEPROM and an 
additional 256 bytes of on-chip static 
RAM, plus an UART. Now, | wonder what 
we can do with this processor... 
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Figure 13, Complete schematic diagram 
of a precision time-interval measurement 
device (or a frequency counter) with seri- 
al data output. The IC is naturally an 
AT908$1 200, 
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If you employ several networked computers, you 


probably don’t have enough desk space, since 
most of the system components are duplicated or 
triolicated. The circuit presented here deals with the 
main culprit by reducing the number of keyboards 


to only one. 
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There are a number of possible ways 
to operate several networked comput- 
ers using only one keyboard, The least 
expensive is no doubt a rotary switch, 
but this is not all that robust mechani- 
cally and is also not easily extended. 
On the other hand, you could buy one 
of the professional switchover boxes 
for keyboards, mice and monitors. 
Although these are practically mainte- 
nance-free (since they work electroni- 
cally) and can be modularly extend- 
ed, they will put you out of pocket for 
at least £100 per connected PC (!). 


Pros and cons 


A nearly ideal solution to this problem 
is a specially designed unit that you 
can build yourself. Although the design 
is modular, you can fit it out fo meet 
your own particular needs. By dispens- 
ing with unnecessary features that are 
found in expensive commercial units, 
the keyboard switch can be made 
both inexpensive and reliable. A quick 
glance at the schematic (Figure 1) 
shows that it does not require any exot- 
ic or unusually expensive components 
— in fact, you may already have most 


Figure 1; The schematic diagram of the 
keyboard switch, showing one full set of 
the circuits to be installed in each PC. 
The circuit in the lower outlined box is 
required for each PC connected to the 
switch; that in the upper outlined box is 
needed for each PC only if PC1 is not 
always switched on. 
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of them on hand. The circuit can be 
easily constructed on a Eurocard and 
can thus be fitted in the enclosure of a 
standard mechanical changeover 
switch (expensive non-mechanical 
units are usually even larger). 


First come, first served! 


The circuit of the keyboard switch is 
designed to be modular, as can be 
seen from Figure 1. It is suitable for 
connecting a single keyboard to up to 
ten PCs. 

The most difficult task is, surprisingly 
enough, handling the supply voltage. 
This is because the individual, possibly 
unequal voltages of the various PC 
power supplies must not be allowed to 
come into conflict. For this reason, the 
keyboard connection of each PC is fit- 
ted with a circuit (shown within the 
upper outlined box) consisting of an 
RC pair, a switching transistor, a two- 
pole reed relay and an optocoupler. 
When PC1 is first switched on, the emit- 
ter of the transistor is connected to 
earth via the coil of the relay. The elec- 
trolytic capacitor is charged via the 
5k1 resistor until the base voltage is 
high enough to cause the transistor to 
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Spicycle 


conduct. This activates the relay, 
which connects the supply voltage to 
the +Ub and —Ub lines. This situation 
will be maintained, even after the 
optocoupler shorts out the capacitor. 
You can guess the purpose of the 
optocoupler: its counterparts in all of 
the other PCs prevent the associated 
relays from being activated. The sup- 
ply voltage is thus always provided by 
the PC with the shortest RC time con- 
stant. If PC1 is switched off, its opto- 
coupler is blocked and the next-short- 
est time constant determines which PC 
takes over the role of power source. If 
PC] is always on in a given network, 
the outlined circuit can simply be 
omitted and the +Ub lines can be 
permanently connected. In this case, 
the connections to +Ub should be 
omitted in all of the other PCs. 


Selection and control 


The switch circuit now has power, but 
not the keyboard, which of course 
must be supplied with power from the 
PC to which if will deliver clock and 
data signals. 

Switching the keyboard between the 
various PCs is handled by a CMOS 


decade counter (4017). When power 
is first applied, the network connect- 
ed to the reset input (CT=0) forces the 
Q0 output to be initially active. An 
oscillator is connected to the clock 
input of the IC (its frequency is just 
under 1 Hz with a 100-F capacitor 
and a 10-k22 resistor). If the pushbut- 
ton switch (with its ‘debouncing’ cir- 
cuit) is pressed, the clock input is 
enabled and the IC counts up at a 
rate of one count per second. 

The outputs of the counter IC control 
two things: a seven-segment display 
that indicates the number of the PC 
that is connected to the keyboard, 
and (via transistors) a group of (reed) 
relays (one for each PC). The two con- 
tacts of the selected relay connect 
the +Vcc and earth lines from the 
selected PC to the appropriate pins 
of the keyboard connector. At the 
same time, the active counter output 
enables two CMOS switches, which 
connect the clock and data lines of 
the keyboard with those of the select- 
ed PC. The circuitry shown in the 
lower outlined box must be fitted in 
each of the PCs. 


Soon the whole world will be on 
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Jump onto the future today - tomorrow’s electronic 
engineering CAD from the lead author of SpiceAge. 
Schematic editing - publication quality images 
Analogue + mixed mode digital simulation with 
extended SPICE-like functions 
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tools cach with high definition visuals 
TrueType fonts 
Back annotation of components from simulator 


Simulate directly from your drawings for the 
ultimate in design checking 
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In spite of fhe slow but steady inroads being made 


by DVD, the CD-ROM is by far the most popular com- 
puter data storage medium. Due to the decreasing 
prices of both CD-R disks and CD-R writers, more and 
more computer users are ‘burning’ their own CDs. 
Modern CD writers offer a wealth of options, so it 
makes sense to describe the most important formats 
and specifications for CD-R and CD-RW. 


CD-R formats 


all about ISO, Romeo, Joliet and UDF 
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When Philips and Sony laid down the 
CD standard in 1980, they probably 
had no idea that the CD would 
become so popular as a computer 
data storage medium. Nearly every 
PC these days has a built-in CD-ROM 
drive, and most software is supplied on 
CD as a matter of course. CD-ROM 
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players have become dirt cheap as a 
result of a rapid series of technical 
innovations and new models devel- 
oped for the computer market. Even 
the ‘CD-burners’, which allow the user 
to make his or her own audio and data 
CDs, have recently dropped signifi- 
cantly in price, so that acquiring a CD 


writer has become increasingly attrac- 
tive for the normal computer user. 
After you have purchased and 
installed a CD writer, you will find that it 
offers an especially large variety of 
options for making various types of 
CDs. Multi-session, CD-Extra and Joliet 
are only a few of the terms that imme- 
diately come to mind. We have 
described all of the options and for- 
mats together here, in the hope of 
helping many (aspiring) owners of CD 
writers to be able to distinguish the for- 
est from the trees. 


From bits to pits 


First let's step back for a moment and 
look at how a CD is made. A standard 
CD consists of a relatively thick poly- 
carbonate disk that contains tracks 
with pits. A thin, reflective aluminium 
coating is applied on top of this, and 
a protective lacquer layer is applied 
on top of the aluminium. The laser 
beam that shines on the CD when it is 
installed in a CD player is focussed 
through the polycarbonate layer onto 
the aluminium layer. A pit changes the 
amount of light that is reflected, and 
this change is detected by a receiver 
in the laser assembly. In this way, ones 
and zeros can be read from the CD. 

A recordable CD (CD-R) uses an 
entirely different construction (see 
Figure 1a). The basic CD again con- 
sists of a polycarbonate layer, but a 
complete track is moulded into this 
layer in the form of a long spiral that 
runs from the hub to the rim of the disk 
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Figure 1, Physical construction of CD-R and CD-RW disks. 


(just as with a ‘normal’ CD). This track 
serves to guide laser assembly. A coat- 
ing of a special organic material is 
deposited on the polycarbonate layer, 
and this organic layer is covered by a 
reflective layer (gold, for example). 
The reflective layer is covered by a 
protective lacquer layer. 

When a CD-R disk is written, the organ- 
ic material is locally heated by the 
laser beam. This changes the reflectiv- 
ity of the gold layer at the location that 
has been heated, and this change 
can be sensed as a pit by a CD read- 
er. Although this is not a ‘true’ pit as 
with a normal CD, it can be ade- 
quately detected by a CD-ROM drive 
or an audio CD player. 

In principle, the relatively new 
rewritable CD (CD-RW) uses the same 
construction as the CD-R (see Figure 
1b). It also has a pre-moulded spiral 
track that serves as a guide for the 
laser assembly. On top of this there are 
two dielectric layers that sandwich a 
special material in which the pits are 
‘purned’. A reflective layer of gold or 
silver sits on top of these layers, and 
finally there is the usual protective lac- 
quer layer. The storage layer can be 
switched between two different phas- 
es (an amorphous phase and a crys- 
talline phase}, depending on how 
quickly it is heated and cooled by the 
laser beam. A lifetime of more than 
one thousand phase changes is possi- 
ble with present-day CD-RW disks. 
Each phase of the storage layer mate- 
tial has a different reflectivity. Since the 
difference between the two reflectivi- 
ties of a CD-RW is less than that of a 
normal CD or a CD-R, CD-RW disks 
cannot be read in all CD-ROM drives. 
Only relatively modern types (and DVD 


el ee 


PC Torpics 


Oe —————— eee 


players) can handle CD-RW disks 
properly; suitable players can be rec- 
ognized by the designation ‘multi- 
read’, 


Data volume 


There is a lot of confusion regarding 
the amount of data that can be stored 
on a CD-R(W). One manufacturer 
specifies a capacity of 650 MB, anoth- 
er claims 700 MB and yet another 
specifies ‘74 minutes’. In principle, all 
CD-Rs have the same capacity, plus or 
minus a few megabytes. The actual 
amount of data that can be stored 
depends on the type of information 
that is to be put on the disk. Figure 2 
compares the various possibilities. The 
length of the tack on a CD is divided 
into minutes and seconds (which 
comes from audio CDs). The ‘basic 
length’ of a standard CD is 74 minutes. 
Each second consists of 75 sectors 
that contain data. Each sector of an 
audio CD contains 2352 bytes (see 
Figure 2a), which would amount to 
almost 747 MB for a 74-minute CD (if 
we calculate using the ‘computer 
thousand’ = 1024). If we take ‘mega’ 
to simply mean one million (as hard- 
disk drive makers like to do), we come 
up with the even more impressive fig- 
ure of 783 MB! 

However, if we want to store computer 
data on a CD, it turns out that extra 
synchronisation data and error-correc- 
tion codes are needed. The original 
standard defines mode 1 and 
mode 2, where mode | includes a sig- 
nificant amount of correction data. 
The result is that each sector can 
effectively contain only 2048 bytes of 
‘user’ data. A CD-ROM can thus con- 
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fain at most (74 minutes) x (60 sec- 
onds) x (75 sectors) x (2048 bytes) = 
650 MB. From this figure, we must sub- 
tract a few megabytes that are 
reserved for session and directory 
information. The XA standard, which is 
also shown in Figure 2, has a some- 
what different structure but still has a 
net data capacity of 2048 bytes per 
sector for mode 2 form 1. 

If you now think that you can use 
mode 2 (or XA mode 2 form 2) to put 
more data on a CD-ROM, you are in 
for a disappointment. These modes 
are only intended to be used for CDs 
where error correction is not particular- 
ly important, such as video CDs. 


Sessions 


In order to later add more data to a 
CD that already contains some data, 
we can ufilize multiple sessions. A ses- 
sion is a block of data that is written to 
the CD by the CD-writer in one pass, 
and it includes a directory section 
placed after the data. A multisession 
CD contains one or more additional 
sessions located after the first session. 
Each time that a new session is added, 
the directory must be updated. This is 
done during the writing process by 
reading the directory information for 
the previous sessions and adding the 
information relating to the current ses- 
sion, to form a new directory that is 
then written at the end of the current 
session. This, and the fact that a lead- 
out (termination of the previous ses- 
sion) and a lead-in (start of the current 
session) must also be added, cause a 
certain amount of storage capacity to 
be ‘lost’: 22 MB for the first session and 
13 MB for each following session. If the 
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1 sector: 2352 bytes 


CD-DA (audio-CD): 


2352 bytes audio-data 


CD-ROM: 


b mode 1 
sync 


header user data EDC | 8 empty ECC 
12 bytes | 4 bytes 2048 bytes 4bytes | bytes | 276 bytes 


mode 2 
sync header user data 
12 bytes | 4 bytes 2336 bytes 


(not used in practice) 


CD-ROM XA: 


header | subheader user data EDC ECC 
12 bytes | 4bytes | 8 bytes 2048 bytes 4 bytes | 276 bytes 


c mode 2 form 1 
sync 


mode 2 form 2 


sync header | subheader user data EDC 
12 bytes | 4 bytes | 8 bytes 2324 bytes 4 bytes 


(EDC = error detection code 


ECC = error correction code) 


982083 - 12 


Figure 2. The available data storage volume on a CD-R(W) is determined by the type of 
information to be stored and the format that is used. 


disk is nearly full or you do not want to 
add any additional information, you 
can ‘close’ the CD so that no more ses- 
sions can be added. After this, such a 
CD-R can be read without problems in 
most CD-ROM players. Modern play- 
ers, by the way, also have no problem 
reading multisession CDs that have not 
been closed. 

Make sure that you choose the proper 
format before you start with the first 
session, since the format cannot be 
changed for subsequent sessions. The 
XA format (mode 2 form 1, often simply 
called ‘mode 2') offers the most 
options and is also handled well by 
older-model CD readers. 

It is also possible to put a new session 
ona CD and ‘throw away’ the old ses- 
sion at the same time. Of course, the 
old session actually remains on the 
disk, but it is rendered invisible to the 
CD player by omitting its directory 
information in the new session. 


File names 


You can choose from several file nam- 
ing options when recording a CD-R. 

1SO09660 is the best-known standard. It 
is the original CD-ROM standard, and 
it represents an attempt to devise a 
universal format that is suitable for the 
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majority of operating systems. In 
ISO9660, a file name consists of eight 
characters ahead of a period and 
three after the period. Only capital let- 
ters, underscores and numerals are 
allowed. 

The DOS format also uses the 8.3 for- 
mat, but allows all characters in the 
ASCII set to be used. Long file names 
(Windows 95) are truncated to eight 
characters before the period and 
three after, with a tilde (~) and a 
numeral placed in the name. 

Long file names are also possible in 
the 1809660 format, but they are limit- 
ed to 30 characters. Names that are 
longer than this are truncated and 
also marked by a tilde and numeral. 
This system is a good choice for CD-Rs 
that must be readable under 
Windows 95 and Unix. 

The Joliet format, which has become 
fairly well known, was developed by 
Microsoft for Windows 95 to allow long 
file names to be used with CDs. A file 
name may contain at most 65 char- 
acters (including spaces) taken from 
the Unicode set. 

The Romeo format offers even more 
room — up to 128 characters per 
name — but it does not support the 
Unicode character set. This format can 
be read by Windows 95, NT and 


Macintosh systems (but only if the 
name is not longer than 31 characters, 
for the Macintosh). 

The HFS (Hierarchical File System) for- 
mat is the standard format for 
Macintosh machines. This format is 
also used by Mac systems for the hard 
and floppy disks. 


UDF 


UDF (Universal Disk Format) is fairly new 
file systern that can be used for CD-R, 
CD-RW, DVD-ROM and DVD-Video. 
Compared to the older IS09660 stan- 
dard, it offers many more options and 
makes it easier to use CD-R and CD- 
RW. For example, UDF allows files to be 
added to an existing CD one at a time 
without any loss of usable capacity. 
With CD-RW, UDF even allows you to 
delete individual files and to store new 
data in the space that is thus made 
available. 

The two most important suppliers of 
software that uses UDF for writing and 
reading CD-R(W) disks are Adaptec 
(with DirectCD) and Cequadrat (with 
PacketCD). 

ACD writer can put data onto a CD-R 
disk in UDF format practically without 
any extra effort, but things are more 
complicated with a CD-RW disk. A CD- 
RW disk must first be formatted, just like 
a hard disk, to divide the disk into 32- 
kB sectors, This procedure, which only 
has to be performed once, takes 
roughly one hour with the current mod- 
els of CD writers. After it has been for- 
matted, a CD-RW disk can be used in 
the same way as a hard disk. 

A lot of storage capacity is lost as a 
result of the formatting, so that the net 
available capacity of a formatted CD- 
RW disk is just under 500 MB. [This nat- 
urally does not apply to CD-R disks). 
With UDF, it is possible to write files to 
the CD-RW and to delete them, 
Current programs are also smart 
enough to regularly choose a different 
part of the CD to use for writing, to 
avoid overwriting certain portions of 
the disk so often that the disk thereby 
becomes unusable (the number of 
write/erase cycles is after all limited). 
As long as a CD in UDF format has not 
been closed, it can only be read in 
the CD writer. This is because the direc- 
tory is only written to the disk when it is 
closed. After it has been closed, the 
CD can be read by any modern CD 
player with multiread capability. If 
problems occur with certain drives, the 
above-mentioned programs allow a 
copy of the CD to be made in IS09660 
format. 
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Writing methods 


There are three basic methods for 
transferring data to a CD. 

In the track-at-once method, the taser 
beam is switched off after each track 
has been written, even if several tracks 
are written fo the CD in one operation. 
This is particularly important when the 
CD contains both data and audio 
tracks or when you are producing an 
audio CD. Normally, the gap (empty 
section) between the tracks lasts 
around two seconds. Some software 
and newer-model CD writers allow the 
length of the gap to be adjusted. 
Some audio CD players have prob- 
lems with the gaps between the tracks 
and may produce noise when they 
encounter a gap. In such cases, the 
disk-at-once writing method is prefer- 
able. In this method, all selected 
tracks are put on the CD in a continu- 
ous chain, without switching off the 
laser beam between tracks. This is of 
course only possible with a CD-R(W) 
that contains only a single session. 

A variation of disk-at-once is session- 
at-once, This can be used when mak- 


The CD books 


ing a CD-R in CD-Extra format, to write 
a session containing several audio 
tracks to the CD in a single operation. 
Since the CD is not closed after the 
session is written, additional sessions 
can subsequently be added to the 
CD. 

The final method is called packet wrif- 
ing. This allows data to be written in 
small packets (normally according to 
the UDF standard), With CD-RW, a fixed 
packet length of 32 kB is used, since 
the whole file system would become 
too complicated (and thus too slow) if 
it had to deal with variable-length 
packets, Variable-length packets can 
however be used with CD-R, since it is 
not possible to overwrite files and the 
fille system thus does not have to 
‘remember’ where space has been 
made free by deleting individual files. 


Practical considerations 


Currently, most CD writers are supplied 
with a program from Adaptec or 
Cequadrat that makes it easy for you 
to burn your own CDs. Often, it is only 


a question of dragging the selected 
files from one window to another, or 
clicking on a button to copy an entire 
cD. 

With the information presented in this 
article, you will probably find that you 
have no problems understanding the 
instructions for the ‘advanced’ settings 
of such programs. Now you know what 
they mean and what you have to 
watch out for. 

A CD-R is a wonderful medium for stor- 
ing more than 600 MB of data at a 
cost of only a few pounds — it has truly 
become an inexpensive medium. If 
you do not yet have a CD writer, 
maybe this will be sufficient incentive 
for you to acquire one. Whether CD- 
RW will become as popular as CD-R 
remains to be seen. The price of the 
CD-RW disk is currently the main obsta- 
cle — for the amount that you pay for 
one CD-RW disk {around £15) you can 
buy ten CD-R disks. Also, in practice it 
turns out that there is not actually all 
that much data that has to be fre- 
quently rewritten. 


The specifications of the various types of CD format are defined in a number of books that are named ofter the colours 


originally used for their jackets. 


Red Book 


This is the original standard for audio CDs, as defined by Philips and Sony more than 20 years ago. Here you will find 
(among other things) specifications for the audio data format, the structure of the tracks on the CD, the maximum num- 
ber of audio tracks (99) and the methods used for error detection and correction. 


Yellow Book 

This js a supplement to the Red Book, which describes how computer data must be put on a CD, It defines two modes: 
mode 1 and mode 2. A later supplement describes the XA format (eXtended Architecture), which allows audio, video and 
computer data fo be placed on a single CD. This supplement was made necessary by the development of the Photo CD. 


Orange Book 
This book specifies the formats for CD-R, magnefo-optical disks and ofher types of (rejrecordabile CDs. It also includes the 
multisession standard, Many of the specifications in the Orange Book are also reused in ofher books. 


Blue Book 

This defines the organizations of the CD-Erasable and CD-Extra formats (also known as CD-Plus or CD-Enhanced). In CD- 
Extra, audio and compufer data are sfored on two separate parts of the CD, with the computer data always placed after 
the audio data to avoid problems with normal audio-CD players. The audio portion is structured according fo the Red 
Book standard and the computer data portion according to the Yellow Book standard. Multisession capability is derived 
from the Orange Book standard. 


Green Book 

The Green Book contains the standard for CD-/, which was brought fo life by Philips. One of fhe most important features of 
this standard is the synchronization of separate audio and video tracks. Both CD-ROM players and audio-CD players can 
usually not read such CDs, 


White Book 
This defines the standards for putting video data on CDs. If also contains the MPEG specification for compressing video 
and audio dafa. Such CDs are organized according to the XA format. 
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We've used superlatives offen enough in Elektor 
Flectronics, but there’s no question that this is the most 
compact computer design we have ever published. 
Just one controller IC and one TIL buffer chip are alll 
that is needed to build a microcomputer with a printer 
port, a serial port and a connection for an LCD. 
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A compact display 
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driving a display or printer using only two ics 
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The AT90S1 200 is the key to this design. You can easily program it yourself, especially 
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since the necessary software can be downloaded free of charge. 


Specifications 


Processor: 
Clock rate: 
Serial input: 
Baud rate 


AT90S1200 

16 MHz 

TIL 

2400, 4800 or 9600 


Serial handshaking: DTR 


Parallel! port: 


Parallel handshaking: 


Display: 
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8-bdit bidirectional; 
Centronics-compatible output 
busy & strobe 

standard LCD module, 2 rows of 16 characters 
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It's simple, really, once you think of it: start 
with a compact but powerful controller 
IC (the AT90S1 200) with built-in ROM and 
ROM, add an HC1245 TIL buffer chip 
and write a few clever software routines. 
The result: a microcontroller with a printer 
port, a serial interface and provision for 
driving a liquid-crystal display. The poten- 
tial applications are too numerous to 
mention. What about supervising a par- 
allel interface or monitoring the commu- 
nications with a serial device, for 
instance? 

Naturally, there are some other compo- 
nents needed in addition to the two ICs, 
but only a few. A 16-MHz crystal and 
two ceramic capacitors take care of 
generating the clock frequency, and a 
trimmer potentiometer allows the dis- 
play contrast to be adjusted, In addi- 
tion, a few small capacitors provide the 
necessary decoupling for the supply 
voltage (see Figure 1). 

The designers have used this circuit as 
a display driver for the printer port of 
an MCS-51 system (note: if can be 
used either as a display driver or a 
printer driver, but not both at the same 
time). It can be connected to the 
MCS-51 system using only three leads; 
+5 V, earth and LPout (Port 1.7, locat- 
ed at pin 8 of the 8032). With only a 
small additional effort, it can be used 
as a universal serial-to-parallel con- 
verter. An interesting feature is that the 
circuit draws so little current (4.6 mA 
when idle, 13.6 mA in the operating 
mode) that the serial port can be used 
as its power source. If it is necessary to 
monitor the connected printer via a 
‘pusy’ line, then an interrupt input can 
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be made available. 

Driving the controller from an MCS-51 
system is relatively simple. First send the 
BASIC instruction BAUD 2400 to select 
the desired serial data rate (rates of 
4800 and 9600 are possible with suit- 
able modifications to the software). 
After this, you can send the data plus 
the instruction PRINT# or LIST# to the 
controller via the serial port, The con- 
troller will then look after presenting the 
information on a display or printing it on 
an attached printer. 


Your own applications 


It goes without saying that this circuit 
lends itself to experimenting. The source 
code for the software is available 
through our Readers Services (order 
number 986030-1). This is extensively 
commented, so it should be possible for 
you to adapt the controller for your own 
applications, independent of the 
example presented here. If on the other 
hand the sample application is just 
what you need, a ready-to-use, pro- 
grammed version of the controller (IC 1) 
is also available through the Readers 
Services (order number 986521-1). The 
software that you will need to do your 
own programming, such as an assem- 
bler and a simulator, is available free of 
charge from Atmel's Internet site. You 
will also find supplementary information 
and sample programs at this site; the 
address is htfp://www.atmel.com, Look 
under the heading ‘products’ for 8-bit 
AVR processors. There you will find 
AVR.EXE in the list of downloadable soft- 
ware. This package includes extensive 
information the form of PDF documents, 
as well as the assembler and debugger 
software. If you do not have access to 
the Internet, the software is also avail- 
able through the Readers Services 
(order number 976017-1). The 
Handyman programmer (published in 
the December 1997 issue of Elektor 
Electronics) is (among others) a suitable 
programmer for the controller IC. 


Your own construction 


A ready-made circuit board for this 
design is not available, since it is 
extremely compact and also particu- 
larly well suited for integration into 
larger designs. In addition, a small 
piece of prototyping board should be 
all that you need in most cases. 

As already mentioned, the circuit can 
in principle draw its operating power 
directly from the serial interface. In this 
case it is essential to use a three-ter- 
minal regulator (such as a 78L05) and 
two capacitors to regulate the supply 
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Figure 1, The complete schematic. Since the entire controller consists of only two ICs, it 


can justly be called extremely compact. 


voltage at exactly 5 V. If the controller 
is used with the previously-mentioned 
MCS-51 system, the necessary volt- 
age is already present; a few mA 
more or less shouldn't make any prac- 
tical difference. 

A standard two-row LCD module can 


Control codes 
PRINT#CHR(1) 
PRINT#CHR{6) 
PRINT#CHR(7) 
PRINT#CHR(8) 
PRINT#CHR(9) 
PRINT#CHR(10) 


circuit reset 


backspace 
tab character 
line feed (LF) 


PRINT#CHR(11) home 


PRINT#CHR{(1 2) 
PRINT#CHR(13) 
PRINT#CHR{(14) 
PRINT#CHR(15) 


erase screen 
new line (CR) 
cursor off 
cursor on 


be used as a display. Adjust the display 
contrast using P1 after power has been 
applied — the adjustment is correct as 
soon as the cursor is clearly visible. Your 
circuit is now ready for use. 


(PROCES. 1) 


switch from printer mode to display mode * 


switch from display mode to printer mode * 


* The control code CHR(?) causes all subsequent data to be sent to the printer. As soon as 
the control code CHR({1) is received, the printer is disabled and all subsequent data are 


sent to the LCD module. 
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Many PCs have a switched mains outlet that enables 
your computer and monitor to be switched on at the 
same time. However, because it is not designed to 
supply high currents, this outlet should not be used to 
switch on too many peripherals. If you want to use 
the on/off switch on your PC to power up the whole 
computer workstation, you should use a so-called 
master/slave switch. Unfortunately, most commercial 
models and kits offer poor performance when switch- 
mode power supplies are hooked up as the master 
equipment. 


Cpesicgm koy T. Scoricarcsr 


master/siave switch 
‘deluxe’ switch on slave devices 


safely and automatically 


To enable the large number of periph- plete with a printed circuit board, and ply. | heard crackling and ticking 
erals connected to his Macintosh to an enclosure with the necessary plug sounds, and sometimes the monitor 
be switched on together with the com- and sockets. Alas, such gizmos do not and other peripherals would suddenly 
puter, the author “got hold of a mas- work very well when the master come fo fife wifh the computer 
ter/slave switch DIY kit fhat came com- device is a switch-mode power sup- switched off.” 
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Musing on this problem the author 
started to design a master/slave switch 
which is virtually immune to voltage 
surges and other irregularities, and 
sent his practical circuit to Elektor 
Electronics. 


The circuit 


The circuit shown in Figure 1 may be 
thought of as consisting of three parts: 
an ordinary 5-V power supply, a cur- 
rent sensor and a comparator with a 
power output driver. The mains voltage 
is connected to K1, the master, to K2, 
and the slave, to K3. Apart from a fuse, 
F1, there is only the current sense resis- 
tor, R5, between K1 and K2. As soon as 
current starts to flow to the master, R5 
drops an alternating voltage which is 
limited to +0.7 V by D5 and Dé. R5, 
incidentally, allows a master power 
consumption of up to 600 watts. Low- 
pass filter R7-C4 removes high-fre- 
quency noise from the alternating volt- 
age. As mentioned above, it is partic- 
ularly this type of noise that wreaks 
havoc in commercial master/slave 
switches. IC2a amplifies the positive 
half-cycles about 3 times, while D7 
blocks the negative half-cycles. In this 
way, a pulsating direct voltage is cre- 
ated whose peak value is stored in 
capacitor Cé. Buffer IC2b completes 
the current-sense sub-circuit. 

The next comparator, IC2c, defines 
the switch-on threshold of the circuit. 
The green low-current LED D8 not only 
acts as an on/off indicator (i.e. circuit 
connected to the mains), but also pro- 
vides a stable reference voltage of 
about 2 volts. Preset P] allows a thresh- 
old to be set that corresponds to any 
master power consumption between 
10 W and 100 W. Resistor R9 adds a lit- 
tle hysteresis to the comparator, pre- 
venting its output from ‘chattering’. The 
red LED, also a low-current type, lights 
when the comparator output drops 
low. This means that the circuit is 
active. Inverter stage T1, finally, is 
included to provide sufficient gate 
current for triac Tril. 

The triac used here is an SGS- 
Thomson device marked by an 
extremely sensitive gate — the device 
is triggered by a current as low as 
5 mA. Moreover, the BTAO4-600T does 
not require a so-called snubber net- 
work that is normally indispensable 
with triacs. The triac is capable of 
switching up to 4 A, allowing slave 
equipment with a power consumption 
of just under 1 kW to be connected. A 
ready-made suppressor coil, LI, is 
included to attenuate transients and 
RF interference. The same triac family 
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1N4007 


IC2 = LM324 
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Figure 1, The circuit of the master/slave switch consists of three functional sections. 


includes types with a switching capac- 
ity of 6 A (BTAO6-600T), and 8 A (BTAO8- 
6008). Although it is possible, in princi- 
ple, to use these devices in the present 
circuit, the PCB then has to be modi- 
fied to cope with the higher currents: 
strengthen the high-current tracks by 
soldering solid wire over them, 
increase the wire diameter of L1 from 
1.0 mm to 1.5 mm, and exchange the 
fuse with a type rated for the higher 
current. 

The circuit has a conventional 
power supply. A small mains trans- 
former, Trl, a rectifier, D1-D4, and a 
reservoir capacitor, C2, provide a raw 
direct voltage which is stepped down 
and stabilised at 5 V by fixed-voltage 
regulator IC1. By the way, the circuit 
itself has a modest power consump- 
tion of just 200 mW. 
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Construction: safety first 


Before you start soldering away, do 
take note of the following: the circuit, 
including the low-voltage section, is 
not electrically isolated from the 
mains. The circuit must, therefore, not 
be built on any other circuit board 
than the one shown in Figure 2, which 
has been designed to comply with 
every requirement in respect of electri- 
cal safety. 

Start the construction of this project 
by fitting the low-profile parts, and 
work your way ‘up’ to the taller parts, 
with the transformer soldered as the 
last Component. The two LEDs are 
mounted at such a height that they fit 
snugly in the holes drilled in the enclo- 
sure fop panel. Two properly isolated, 
transparent lenses not only contribute 
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Figure 2, The carefully designed PCB ensures safe constructing. 


onsen 


Figure 3. It is essential that the circuit be mounted so that it can not be touched when 
in operation. 
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COMPONENTS LIST 


Resistors: 

R1,R2 = 33kQ 
R3,R6,R14 = 1kQ 
R4 = 15kQ 

R5 = 323,0.5W 
R7 = 27kQ 
R8,R10 = 8200 
RS = 220k22 

Ri1 = 10k 

R12 = 22k 

R13 = 82 

P1 = 10k22 preset H 


Capacitors: 
C1 = 47nF 630V (Class X2) 


C2 = 220uF 25V radial 
C3 = 47uF 16V radial 
C4,C5 = 100nF 


C6 = 10uF 16V radial 
C7 = 10nF 


Semiconductors: 

D1...D4 = 1N4001 

D5,D6 = 1N4007 

D7 = 1N4148 

D8,D9 = LED 

T1 = BC557 

Tril = BTA04-600T (SGS-Thamson) 
iC1 = 78L05 

IC2 = LM324 


Miscellaneous: 

F1 = Fuse 6.3A slow with PCB mount 
holder 

K1,K2,K3 = 3-way PCB terminal block, 
pitch 7.5mm 

Tr1 = mains transformer, PCB mount 
(Conrad Electronics o/n 506052) 

L1 = suppressor choke 65 wH/5 A 
(Conrad Electronics o/n 534439) 
Heatsink for Tri1 (Fischer SK59) 


2 LED lenses, transparent (Conrad 
Electronics o/n 539910) 

PCB, order code 982063-1 (see Readers 
Services page). 


to the ‘professional’ look of the mas- 
ter/slave switch, but also afford touch 
protection — after all, the LEDs, foo, 
may be af mains potential! 

The completed and _ (visually 
inspected) circuit board is mounted 
‘touch-proof’ in an ABS case. Our lab 
prototype is shown in Figure 3. Please 
be sure to undertake the adjustment of 
P1 with an insulated screwdriver — we 
do want to keep you as a reader! 

(P820e3- | J 
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Now chip cards, and, 
perhaps more particu- 
larly, smart cards, are 
_ widely used in large 
yarts of the world ina 
variety of applications, 
communications engi- 
neers have come up 
with another one: 
_. Radio Frequency 
Identification (RFID) 
readers. In this appli- 
cation, chipcards are 
used in conjunction 
with resonant circuits 
(antennas), but wire- 
~ less and without 
physical contact, for 
the identification of 
_. persons, animals, 
bjects or for process 
~ control. The tech- 
nique is not new, but 
means of applying 
it is. 


By editorial staff 
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GENERAL INTEREST 


RFID systems 


using smart cards 


Control Board 


Circuitry 
Connector 1 
Power 
Supply 


Antenna Board 


In essence, a Radio Frequency [Denti- 
fication (RFID) system (a typical setup is 
shown in Figure 6) consists of a _trans- 
mitter-receiver to transmit an interro- 
gation signal and receive an acknowl- 
edgment from the responder in the 
interrogated reader (RFID device). A 
similar system in terrestrial communi- 
cations is called a relay or repeater sta- 
tion, and in satellite communications, 
a transponder. 

In many applications, the respon- 
der, that is, the part of the reader that 
replies automatically to a correct inter- 
rogation signal, is passive. This means 
that the radio frequency field gener- 
ated by the antenna is used not only to 
transmit the requisite data, but also , by 
induction, to supply the necessary 
energy for the responder. This is the 
real novelty in the use of chipcards. 

The use of chipcards in a contact- 
less and wire-less manner has a further 
advantage in that it allows a variety of 
constructions to be employed. An 
RFID reader can be integrated in 
objects like rubbish bins or transport 


containers, and, owing to its small size, 
be implanted into people and animals. 
They may also be incorporated in 
bracelets or wristwatches or, indeed, in 
cheque cards. 


RFID READER 

As in the case of chipcards in general, 
an RFID system has a reader for receiv- 
ing and evaluating an interrogating sig- 
nal from a transmitter-receiver. Only in 
key systems and similar applications is 
the reader a read-only device. In most 
other systems a reader's programmed 
information may be modified (written) 
by the user, so the reader is a read/write 
device. 

A simple reader consists of a small 
module which only needs an antenna 
and a supply voltage. The antenna usu- 
ally consists of a small inductor whose 
dimensions depend on the frequency 
range in which the system operates 
and the working range needed. 

Ina simple key system, the module 
has a switched output to which a relay 
may be connected or via which an elec- 
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tric door opener is controlled. All this 
happens, of course, only if the interro- 
gation signal is evaluated by the micro- 
controller in the module as correct. In 
more complex applications, the evalu- 
ation is followed by the programming 
of the system by a small computer. The 
reader is then provided with a suitable 
interface. 

The block diagram of such a reader 
is shown in Figure 1, This is a version 
of the MIFARE® Serial Proximity 
Reader from Philips/Mikron. It consists 
of a VLSI (Very Large Scale Integration) 
Reader Chip, an RF module, an 
antenna and a microcontroller for the 
serial interface. These are mounted on 
a printed-circuit board (PCB) with the 
RF part of the circuitry being shielded 
by a ferrite against the electromagnetic 
influence of the electronic part. 

The reader operates at the standard 
ISO (International Organization for 
Standardization) frequency of 
13.56 MHz. The operating range is 
about 10 cm (4 in). The signalling speed 
is 115 kilobaud. 

This type of card is used primarily 
in slot or surface readers, such as ATMs 
(Automatic Teller Machines), vending 
machines, parking meters, and public 
telephones. 

In most other RFID applications, 
the operating frequency is lower: 
100-450 kHz, which enables larger 
operating ranges. The most popular 
frequency is 125 kHz, but 120 kHz, 
134.2kHz and 150kHz are also 
encountered quite often. The fre- 
quency of 134.2 kHz is used primarily 
in Texas Instruments’ TIRIS system. 

The antenna is a round, rectangular 
or square, potted, air-cored inductor or, 
in the 100-200 kHz range, a ferrite rod. 

Figure 2 shows a read/write module 
with integrated passive antenna for 
use in 13.56 MHz RFID systems. This 
module is controlled via a serial inter- 
face (RS232). The operating range is 
about 25 mm (1 in). 

Larger operating ranges, up to a 
few metres, are achieved with operat- 
ing frequencies in the 100-200 kHz 
range, and rectangular inductors that 
form effective frame antennas. The 
sides of such an antenna may be up to 
one metre long. Clearly, the electronic 
circuits are then separate from the 
antenna, which is located, for instance, 
in the entrance/exit gate of a shop, 
store or car park, When the distance 
between reader and antenna is large, 
active antennas or used. 


CARD ICS 

The heart of a contactless smartcard is a 
card IC. This single chip stores the data 
to be transmitted and ensures their 
secure transfer. The IC is usually 
mounted together with the capacitor 
for the resonant circuit on a small 
wafer as shown in Figure 3. All this 
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module needs is a coil (antenna) to be 
connected to its two terminals, 

Figure 4 shows the block diagram 
of a typical 13.56 MHz card module. 
The functional groups at the righthand 
side of the diagram, that is, the digital 
section, are found in most smartcards. 
An exception is the anti-collision facil- 
ity, which enables the reader to func- 
tion with a number of cards in its cap- 
ture range — which is, of course, impos- 
sible with a standard chipcard. 

The RF interface, in conjunction 
with a tuned antenna connected to the 


two terminals at the side, provides the 
wire-less connection (including the 
supply voltage) to the reader. The 
design of the antenna depends on the 
operating frequency, the dimensions of 
the enclosure, and the desired operat- 
ing range. 


FUNCTIONAL 
DESCRIPTION 

Generation of the necessary supply 
voltage and modulation is achieved by 
two loosely coupled resonant circuits 
as shown in Figure 6. 
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The supply voltage 
is obtained from the 
electromagnetic field 
induced on the attached (antenna) coil. 
The RF voltage is rectified to provide 
the requisite direct voltage. When this 
voltage crosses the power-on level, the 
RFID reader enters the standard read 
mode and sends data continuously. 
The data to be sent in this mode is 
user-defined by storing the first and 
last addresses to be output. When the 
last address is sent, the device will con- 
tinue with the first address until the 
transmitter-receiver sends a request. 

In the read mode, a listen window 
(LIW) is generated before each word. 
During this time, the 
reader will turn to the 
receive mode (RM) if it 
receives a valid RM 
pattern. The reader 
then expects a valid 
command. 

A 1024 bit EEPROM 
in the RFID reader is 
organized in 32 words 
each of 32 bits. The first 
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three words are 
assigned to the pass- 
word, the protection 
word, and the control word. To write 
one of these words, it is necessary to 
send a valid password. The password 
cannot be read out. The memory con- 
tains two extra words of laser ROM. 
These words are laser programmed 
during fabrication for every IC, are 
unique and cannot be altered. 

The data modulator in the trans- 
mitter-receiver is driven by the serial 
data output from the memory in the 
RFID reader which is encoded. The 
modulator will draw a large current 
from both coil terminals, thereby 
amplitude modulating 
the RF field according 
to the memory data. 

The RFID reader 
modulates the ampli- 
tude of the RF field to 
transmit data to the 
transmitter-receiver. 
Data are output serially 
from the EEPROM and 
Manchester encoded. 


Different patterns are used to send 
status information to the transmitter- 
receiver, Their structure cannot be 
confused with a bit pattern sequence. 
These patterns are the listen window 
(LIW) to inform the transmitter- 
receiver that data can be accepted, the 
acknowledge (ACK) indicating proper 
communication and end of EPROM 
write, and the no-acknowledge 
(NACK) when something is wrong. 

The LIW, owing to its special struc- 
ture, can be used to synchronize the 
transmitter-receiver during a read 
operation. It is sent before each word. 

The RFID reader can be switched to 
the receive mode only during a listen 
window. The transmitter-receiver is 
synchronized with the incoming data 
from the reader and expects a LIW 
before each word. During the phase 
when the reader has its modulator on, 
the transmitter-receiver has to send a 0. 
A certain phase shift in the read path 
of the transmitter-receiver is acceptable 
since, when entering receive mode, the 
transmitter-receiver becomes the mas- 
ter. 

At reception of the first 0, the RFID 
reader stops the LIW sequence and 
then expects another 0) to actuate the 
receive mode. Once the reader has 
received the first 0, the transmitter- 
receiver is imposing the timing for syn- 
chronization, The reader turns on its 
modulator at the beginning of each 
frame of a bit period. 

To send a logic 1, the transmitter- 
receiver continues to send clocks with- 
out modulation, Half a bit period later, 
the modulation device in the RFID 
reader is turned off, allowing the inter- 
nal supply capacitor to be recharged. 

To send a logic 0, the transmitter- 
receiver stops sending clocks (100% 
modulation) during the first half of a bit 
period. The transmitter-receiver does 
not turn off the field during the first 7/4 
clocks of the bit period. The field is 
stopped for the remaining first half of 
the bit period and then turned on again 
for the second half of the bit period. 
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RF ra Data 


‘To ensure synchronization between 
the transmitter-receiver and the RFID 
reader, a 0 is transmitted at regular inter- 
vals, The RM pattern consists of two bits 
set to 0, so allowing initial synchroniza- 
tion. In addition, the chosen data struc- 
ture contains even parity bits which will 
not allow more than eight consecutive 1s 
where no modulation occurs. 

While the transmitter-receiver is 
sending data to the RFID reader, two 
different modulations will observed on 
both coils. During the first half of the 
bit period, the reader switches on its 
modulation device causing the RF field 
to be modulated. This modulation can 
also be observed on the transmitter- 
receiver coil. When the transmitter- 
receiver sends a 0, the RF field is 
switched off, causing 100% modulation 
on the reader coil. 

The transmitter-receiver may con- 
sist of a single IC, such as the 90106 
from Melexis UK, the block diagram of 
which is shown in Figure 7. 

In this, there is a modulation input 
(MODU) for the oscillator. The RF sig- 
nal can be shifted by a direct voltage of 
0-3 V applied to this input (0 V is peak 
value; 3 V oscillator disabled). If the 
input is left unterminated, the (internal) 
modulating voltage is 15. This 
ensures the best sensitivity for the RFID 
reader, whose data are available at the 
DATA pin. The coil parameters are cal- 
culated as shown in the box. 

Apart from amplitude modula- 
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tion (AM), RFID systems may use 
Manchester encoded AM, phase- 
shift keying (PSK), frequency shift 
keying (FSK), and frequency modu- 
lation (FM). 


CONSTRUCTION 

Since RFID readers consist of an IC and 
an antenna only, their enclosures can 
take many shapes and be of many 
types of material. Polyester and plastic 


transponder coil 
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cases dominate in the small units, 
whereas the more robust types use 
metal carrier plates. Units for use in 
damp conditions or in chemical plants 
are hermetically enclosed in glass 
cases. Some are very small (2mm 
diameter and 12 mm long) and there- 
fore suitable for implanting into farm 
animals or domestic pets for recogni- 
tion purposes. Implanting is carried by 
(virtually painless) injection under the 
skin with the aid of a special veterinary 
gun. 
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RFID readers come in the shape of 
cards, disks, pills, or rods. Pill-shaped 
units are particularly suitable for iden- 
tification of pallets, containers, and 
motor vehicles, while small rod-shaped 
ones are used for integrating into car 
keys. Small units (glass or plastic) used 
for animal implantation, called animal- 
IDs are designed and produced to a 
standard ISO protocol: ISO 11784/85. 

RFID systems and components are 
available from a number of manufac- 
turers as listed below. [t should be 


noted, however, that, owing to the spe- 
cialized equipment needed, this field is 
not suitable for home design and/or 
construction. It may, of course, become 
so during the next few years, but the 
signs are not encouraging. 

Ready-made small systems for, say, 
electronic locks are, however, available 
from some stockists. Also available 
from several manufacturers for the 
professional designer are development 
and demonstration kits. 


MISCELLANEOUS 

Information from the following man- 

ufacturers was used in the prepara- 

tion of this article. 

Philips/Mikron (The Netherlands) 

Melexis UK (United Kingdom) 

Siemens (Germany) 

Temic (Telefunken Microelectronics) 
(Germany) 

Texas [Instruments (USA) 

EM Microelectronic-Marin (Switzer- 
land) 


Philips, in association with Mikron, has 
a range of RFID products under the 
name Mifare®. This range includes 
readers for use at 13.56 MHz with an 
operating range of about 10 cm. The 
company also produces Hitag units for 
operation in the 125 kHz band with an 
operating range of up to one metre. 

Telefunken Microelectronics offers 
a range of RFID readers in the 
100-400 kHz range. These units are 
inexpensive and particularly intended 
for large-quantity production. The 
range includes a read-only version that 
has a 128-bit PROM and can be used in 
the 100-400 kHz range at temperatures 
from —40 °C to +125 °C. The write unit 
is intended for use in the 100-150 kHz 
band. 

Texas Instruments has a family of 
RFID readers, named TIRIS, that 
ranges from contactless 64-bit chip- 
cards to heavy-duty units for use in 
goods vehicles and containers. All units 
operate on the same frequency of 
134.2 kHz, and use frequency-shift key- 
ing (FSK). Many units in the range can 
operate at distances of up to two 
metres, which necessitates the use of 
large frame antennas for the reader 
and ferrite rod antennas for the trans- 
mitter/receiver. The largest unit in the 
TIRIS range is housed in a glass tube 
31 cm long and 4 cm in diameter. 


More information may be obtained 
from ‘Transponder News’, Internet 
News Services: 
www.rapidttp.com/transponder 


In the United Kingdom contact 
Melexis UK, 3 Anglesey Close, Chase- 
town, Staffs WS7 8XA; telephone/fax 
01543 670391. 


[9801099| 
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Calculating the inductor 


In the following it is assumed that the (RFID) reader operates at a frequency of 120 kHz. So as to minimize the influence of parasitic 
! capacitances on the resonant frequency of the RC circuit, it is advisable to keep the value of the inductance as low as feasible (since 
this requires a larger circuit capacitance, C). 
| The fieldstrength produced by the inductor, H, is directly proportional to the number of turns, n, and the current, i, flowing through 


the coil: 
H=niz=nvi[ol [Eq. 1] 
where v is the alternating voltage across the coil, L is the self-inductance of the coil, and w is the angular frequency, that is, 2xf. 
| The self-inductance of the coil is directly proportional to the square of the number of turns: 
L=Ln?, [Eq. 2] 
where L, is the self-inductance of a single turn of the coil. 
Combining the two equations yields: 
H=violon [Eq. 3] 


Equation 3 shows that a reduction of the number of turns increases the fieldstrength (and simplifies winding the coil). 
Practical values for a 120 kHz resonant circuit (antenna) are 0.025 uF for the capacitor and 70 wH for the inductor. Such an (air- 
cored) inductor would consist of 30 turns with a diameter of about 30 mm. 


TERMS USED IN 
RFID SYSTEMS 


Anticollision 

A facility to enable the system to recog- 
nize the correct RFID units when a num- 
ber of these units are within the operat- 
ing range, 


Delta modulation (DM). In delta modula- 
tion, the level of the sampled analogue 
signal is coded by one bit, positive or 
negative, based upon whether a signal 
sample is greater or smaller than the pre- 
vious value. Because only one bit per 
sample needs to be transmitted, the sam- 
pling rate can be increased significantly 
to reduce the quantization noise, sim- 
plify the anti-aliasing filter, and reduce 
the bandwidth required for transmis- 
sion. 


Delta-sigina modulation (DSM). Delta 
modulation systems cannot handle sig- 
nals with a d.c. component and have a 
signal-to-noise ratio that is sampling 
and modulation frequency dependent. 
Both of these disadvantages are over- 
come by using the delta-sigma tech- 
nique, which employs an integrator cir- 
cuit at the input to the modulator. The 
amplitude of the output pulses then con- 
veys information about the signal ampli- 
tude and not just its variation. 


Frequency shift keying. Non-coherent 
demodulation produces two channels in 
the decoder, each processing the 0 and 1 
frequency respectively. Envelope detec- 
tion in each channel then produces a 
pulse to coincide with the transmission 
of each 0 or 1. The output bit stream is 
finally produced by combining the two 
channel outputs. The coherent technique 
uses two product detectors, one for each 
channel or bit carrier frequency. The 
decoded data stream is obtained again by 
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combining the two channel outputs. 
Manchester code. This is a bi-phase format 
in which each bit in the original signal is 
represented by two bits in the derived 
format. The basic rule for the transform 
is that 0 is represented by 01 and 1 by 10. 
This ensures that there are never more 
than two identical bits in series. 


Multifunctionality, This term pertains to a 
card that can be used for several differ- 
ent purposes; for instance, a bank card 
combined with a credit card 


Multipage transponder (MPT). A trans- 
ponder whose memory is organized in 
several pages, for instance, 1360 bits in 17 
pages each holding 80 bits. 


Multiple security (access). Access control to 
a communications system according to 
the security status of the user, and the 
degree of classification of the facility 
required, 


Phase shift keying. Only coherent decod- 
ing can recover the data from sucha 
modulated signal. It is, therefore, pre- 
filtered to narrow the detection band- 
width and minimize the noise before 
being input to a product detector stage. 
Low-pass filtering is used to recover the 
data stream from the unwanted har- 
monic components of the carrier fre- 


quency. 


Read only. An RFID device whose pro- 
grammed information cannot be modi- 
fied. 


Read/write (R/W). An RFID device whose 
programmed information may be 
altered by the user. 


Responder. That part of an RFID reader 
that automatically transmits a reply to 
the interrogating transmitter-receiver. 


Responser. The receiver in an RFID 
reader that accepts and interprets the 
signals from the interrogating transmit- 
ter-receiver, 


Selective addressable multipage transponder 
(SAMPT). A transponder similar to an 
MPT but whose first page holds a 24-bit 
address data field, which can be pro- 
grammed by the user to enable one of a 
group of transponders to be accessed 


Smart card. A plastic credit card sized 
device in which some simple computing, 
facilities are embedded. The card con- 
tains typically a purpose-developed 8-bit 
microprocessor accompanied by up to 
20 kbytes of ROM to carry the applica- 
tion program, 4 kbytes of EPROM that 
provides non-volatile memory of the 
card user status, 512 bytes of RAM to 
hold the data associated with the calcu- 
lation for a single transaction, and regis- 
ters that may be 512 bits long. There are 
currently two types of this card: one 
with contact pads along one edge sur- 
face, and the other that is accessed via 
radio-frequency signals, The latter was 
developed for use in the GSM mobile 
telephone service in which the user has 
to input a personal identity number 
(PIN), and if this is accepted, the user 
can proceed to the next stage. 


Tag. A device attached to an item to be 
tracked. There are two basic concepts: 
active and passive. An active tag is pow- 
ered by a long-life battery, whereas a 
passive device is signal-powered. An 
RFID reader may be used as a tag. 


Transponder. (1) The name given in satel- 
lite communications to what is called a 
relay or repeater system in terrestrial 
communications. (2) In radar engineer- 
ing a form of transmitter-receiver that 
automatically transmits signals when the 
correct interrogation is received. 


TEST & MEASUREMENT 


It is just about ten 
years ago that this 
magazine published 
design of a barom- 
r/altimeter. In these 
en years electronics 
technology has pro- 
gressed to develop- 
ments that were 
nimaginable then. The 

_ present barometer/ 
Itimeter is based on 

recision air- 
ressure sen- 
sor with inte- 
gral signal 
processor 
om Motorola. 

Evaluation, 


Features: 

X Barometer function 

X Altimeter (absolute or relative height measurement) 

X Height measurement from -2000 m to +10000 m 

X Relative height measurement referred to arbitrarily chosen height 
X 1 or 2 point calibration 

X EEPROM aaia logger for 1000 samples 

X Log interval from 10 seconds to 8 hours 

X Log data retrievable sample by sample from the computer 
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Gently tapping and looking at the 
usual (aneroid) domestic barometer 
does not really say much about the 
weather that can be expected. Much 
more telling is the drift of the barome- 
ter, which shows the speed, magnitude 
and direction of variations in atmos- 
pheric pressure. This information gives 
a good idea of the weather to be 
expected over the next few hours. 
Unfortunately, an aneroid barometer is 
not very accurate: a mercury type (not 
often found in domestic premises) is 
better, but is nowhere near as robust 
and convenient to use. Note that fre- 
quent tapping does not do the barom- 
eter much good. 


ATMOSPHERIC 
PRESSURE AND HEIGHT 
If a barometer is to be used in a 
weather station or in conjunction with 
an external temperature controller in a 
heating installation, it should be a 
microcontroller-driven model. Such a 
unit is very accurate and offers a num- 
ber of additional facilities as in the pre- 
sent design. 

The present design has a total max- 
imum error of not more than two per 
cent, which is very small for a barome- 
ter. It also enables the measurements to 
be stored or to be supplied to a com- 
puter. 

Apart from atmospheric pressure, a 
barometer can, at least in principle, 
show the height above sea level. But in 
this, other factors such as humidity and 
temperature also play a role. Unfortu- 
nately, the present design cannot com- 
pensate for these factors, since that 
would make it much more complex. To 
use a barometer as an altimeter, it 
needs a different scale. The relation- 
ship between the real atmospheric 
pressure, p, at a certain height, fz, and 
the atmospheric pressure at sea level, 
PIs given by Equation 1: 


h P\= [Eq. ] 
Ps {| 22.555x10 


A distinction must be made 
between relative height and absolute 
height. A relative height, h,, is referred 
to an arbitrarily chosen height, h,,: 


(Eq. 2| 


where /1, is the relative height, p, is the 
atmospheric pressure at fi,, and the 
other parameters are as in Eq. 1. 

Measuring relative height can only 
be done accurately when the atmos- 
pheric pressure at the reference height 
is virtually constant. 
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The absolute height, /,, is referred 
to sea level and is calculated with 
Equation 3: 


‘<A 
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. [Eq. 3] 


Since the measured absolute height 
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depends solely on the atmospheric 
pressure at sea level, p, must be regu- 
larly checked and adjusted in accor- 
dance with the actual pressure at sea 
level when extended measurements 
are carried out. 


SENSOR 

The atmospheric pressure is evaluated 
by a Barometric Absolute Pressure 
(BAP) sensor Type MPXS4100A from 
Motorola. The sensor contains a thin 
diaphragm that is depressed to a 
greater or lesser degree by atmospheric 
pressure (Figure 1). A piezoelectric ele- 
ment fused along the edge of the 
diaphragm faithfully follows the move- 
ments of the diaphragm. In doing so, 
its resistance varies in direct proportion 
to the movements and thus to the 
atmospheric pressure. In other words, 
the sensor behaves as a potentiometer. 


Diaphragm 


Sealed Vacuum 
Behind Diaphragm 
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PINS 1 AND 5 THROUGH 8 ARE NO CONNECTS 


When a supply voltage 
is applied across it, the 
resulting output volt- 
ages varies in direct 
proportion to the vari- 
ations in pressure. 

There are three 
kinds of pressure sensor. In a differen- 
tial sensor pressure is applied to both 
sides of the diaphragm, whereupon 
the device provides a voltage that is 
directly proportional to the difference 
in pressure at the two sides. 

The standard pressure sensor is 
constructed along similar lines as the 
differential model. This type uses the 
ambient pressure as reference, so that 
the output voltage is proportional to 
the relative pressure. 

In the absolute-value sensor, used in 
the present design, the space behind 
the diaphragm is isolated from the 
environment and evacuated to a refer- 
ence pressure (Figure 2). The output 
voltage is proportional to the absolute 
atmospheric pressure, which makes it 
suitable for use in a barometer, altime- 
ter or mobile weather station. The sen- 
sor was originally developed for use in 
motor vehicles and is consequently 
readily available at a 
reasonable price. 

The sensor provides 
an output voltage of 


Vg = 5.1 Vde 
TEMP = 0 to 85°C 


MPXS4100A 


OUTPUT (Volts) 


y i 


TRANSFER FUNCTION: 
Vout = Vs" (,01059°P-.152) + Error 
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0.34.9 V, which is 
directly proportional to 
a pressure range of 
20-105 kPa 
(200-1050 millibar). It 
=. has anerror of only 1.8 
per cent over the tem- 
perature range 0-85 °C. [t can operate 
at temperatures down to 40 °C and up 
to +125 °C. It can withstand pressures 
of 400 kPa (continuous) and 1000 kPa 
(burst). 

The sensor element (Figure 3) also 
contains temperature compensation 
circuitry, two amplifiers, and shift cir- 
cuitry that converts the differential 
measurement potential into one 
referred to ground. Altogether, it pro- 
vides a linear output signal over the 
pressure range 20-105 kPa with a sen- 
sitivity of 54 mV/kPa (Figure 4). The 
relevant transfer function is 


Vout = V<(0.01059p-0.1518)+E, 


where 

V,=5.1V +0.25V 
p = pressure in kPa 
E = total error 


The linear relationship 
and the output voltage 
range allow easy con- 
nection to an analogue- 


20 KPA TO 105 kPA Bias 
ake 


to-digital converter (ADC) and a micro- 
controller. 


ANALOGUE-TO- 
DIGITAL CONVERTER 
The analogue-to-digital converter is 
based on a 16-bit sigma-delta converter 
Type AD7715-5 from Analog Devices. 
Although at first sight a resolution of 
16 bit seems a little over the top, it 
should be noted that when the device is 
used as altimeter this provides a reli- 
able height resolution of one metre, 
provided that the ambient pressure is 
fairly constant. 

The AS7715 has a balanced input 
buffer and a programmable amplifier 
(PGA). Nevertheless, since input AIN- 
as well as REF [N— are at ground 
potential, the converter operates in 
unbalanced mode and requires an 
input signal of 0-2.5V (when the 
amplification of the PGA is x1). This 
setup requires two potential dividers 
between sensor and converter to halve 
the input signal (R,-R3) and the refer- 
ence voltage (R3-R4), The voltages are 
decoupled by capacitors C) and Co. 

The input signal and reference volt- 
age are applied to a sigma-delta mod- 
ulator, which is terminated into a digi- 
tal filter. The digital output, DOUT, is 
available in serial form, thus allowing 
easy connection to a microcontroller. 

The converter provides the con- 
troller with various facilities for influ- 
encing the overall operation. For 
instance, apart from the 16-bit data reg- 
ister, there are three 8-bit registers that 
can be read serially or set via DIN 
(Communication, Setup and Test). 

It is important to note that the con- 
verter has a self-calibrate facility which 
is instigated by a relevant instruction 
from the microcontroller. 

The converter is clocked by an inte- 
gral crystal (X,) oscillator that operates 
at 2.4576 MHz. The clock signal is avail- 
able at SCLK. 


MICROCONTROLLER 

The microcontroller is an 8051-derived 
Type AT89853-12 from Atmel. The use 
of a single IC for this purpose requires 
it to have RAM and ROM on board. 
These are both relatively small: a 
12 kbyte flash-ROM in which the 
larger part of the program and all the 
constants are stored, and a 2568 bit 
RAM that holds the stack and the vari- 
ables. This means that the computa- 
tions cannot be carried out with float- 
ing-point arithmetic, but have to be 
effected by quite cumbersome mathe- 
matical conversions. This will be 
reverted to in Part 2 next month, 

Port 1 is used for controlling the 
ADC, reading the measurement data, 
and communication with the com- 
puter via the RS232_ interface 
(MAX233). 

Ports 0 and 2 are used for driving a 
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liquid-crystal display (LCD) and for 
inquiring after the operational settings 
of switches S3-S, located on a separate 
interface board. 

The controller is also connected to 
an EEPROM that is driven serially via 
a two-wire link. This device has a stor- 
age capacity of 16 kbit to enable up to 
one thousand 16-bit samples to be 
stored. 

The controller has a serial program- 
ming interface and can be erased and 
programmed in circuit (thanks to 
flash), The use of an in-system pro- 
grammable (ISP) controller is very 
effective in this kind of application. 
Apart from the programming facility, it 
allows modifications to be entered into 
the software. More about this in Part 2 
next month. 


MEASUREMENT ERROR 

As in all electronic measuring equip- 
ment, each and every part and compo- 
nent contributes, in however small 
degree, to the overall measurement 
error. As already mentioned, the sen- 
sor proper has a maximum error, E, of 
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+1.5 kPa (+15 millibar) over the tem- 
perature range 0-85 °C. The error is up 
to three times as great (because of the 
temperature-error factor—TF) over the 
temperature ranges —40 °C to 0 °C and 
+85 °C to +125 °C. The overall error is 


E = +(1.5xTFX0.01059 x V,) 


which is taken account of in Figure 4. 

The input signal is halved by poten- 
tial divider Ry-R>. The tolerance of 
these resistors may cause and addi- 
tional error of up to two per cent in the 
output voltage. The same is true of the 
resistive divider halving the reference 
voltage. From this it is clear that these 
resistors should be carefully selected, if 
at all possible. 

Another possible source of error is 
the ADC. Fortunately, as mentioned 
earlier, this has a self-calibrate facility 
which sets the reference point and the 
maximum output correctly every time 


the unit is switched on and every 
thirty minutes thereafter. 

Any errors caused by the amplifiers, 
temperature variations and missing 
codes may be ignored. Only the non- 
linearity of the ADC (0.0015 per cent) 
must be included in the error compu- 
tation. 

Allin all, the controller is supplied 
with data that have an error of not 
more than 1.8 per cent if the unit is 
carefully balanced, and up to 5.8 per 
cent in an unbalanced unit. 


SUPPLY VOLTAGE 

The supply voltage is derived from a 
12 V mains adaptor or a 9 V dry or 
rechargeable battery. Since the unit 
draws a current of up to 25 mA, oper- 
ation from a dry battery is, however, 
not recommended. The mains adaptor 
and rechargeable battery may be used 
together: diodes D; and D, prevent 
any interaction. 
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The voltage is stabilized at 5 V by 
micropower voltage regulator IC, 
which requires a quiescent current of 
only 75 vA and creates a voltage drop 
of not more than 400 mV. The device 
can handle output currents of up to 
100 mA. 

Immediately following the regula- 
tor, preset P; serves to set the contrast 
voltage, Ug, for the LC display. 

The supply voltage to the various 
digital ICs is taken direct from the reg- 
ulator output pin, whereas that to the 
sensor and the reference voltage input 
of the DAC is decoupled by chokes L, 
and Lp. 


CONSTRUCTION 
Before any construction work is 
started, the double-sided printed-cir- 
cuit board in Figure 6 must be cut into 
two. The smaller portion houses five 
push-button switches and connector 
Ky. When these have been put into 
place, fix it to the cover of the enclosure 
after this has been prepared according 
to the front panel layout in Figure 7. 

Owing to the narrowness of the 
tracks and the dense population of the 
larger portion, it is imperative to use a 
small soldering iron and to take even 
greater care than usual to avoid solder 
splashes on the board. It hardly needs 
saying that great care must be taken 
also to ensure correct positioning of all 
components, especially polarized ones. 

When the board has been com- 
pleted (it should look more or less as 
the prototype shown in Figure 8), fit it 
into the enclosure, and close this with 
the cover prepared as described earlier. 

In next month's Part 2, the pro- 
gramming, calibration, software and 
operation will be described. 
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* mentioned article we came 
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offering products 
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ation on CD-R(W) | 


where to find 
background facts 


related (one way or 
another) to CD-R(W). 
For example, Adaptec 
supplies software for CD- 
ROM burners — their 
site offers clear explana- 
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tions of various CD-R 
related terms, as well as 
an extremely useful CD- 
R glossary: 
http://www.adaptec.com/ 
support/overview/ 
cdrecbackground html 

The web site run by 
Audio Images Interactive 
Group (AIIG) also has a 
wealth of information, 
especially on the CD- 
Extra: 
hitp://www.bway.netiatig/ 

Another web site you 
should not forget to visit 
is that of Octave, an 
American company spe- 
cialised in selling CD 
recorders and ancillaries. 
Their site allows you to 
browse the on-line ver- 
sion of Ricoh’s extremely 
interesting “Recordable 
Handbook’: 
http://www.cd-r.com/ 
library/ricoh/ 
cdrhandbook.html 

Octave’s site contains 
more interesting stuff, by 


the way, at: 
http://www.cd-rom/ 
library.html 

Finally, a useful 


address for those who 
feel like exploring the 
intricacies of the ISO9660 
format without having to 
wade through the official 
documentation: 
http://www.coe.neu.eduf 
~riker/1SO9660. html 

At this site, Philip J. 
Erdelsky in his article ‘ISO9660 Sim- 
plified for DOS/Windows’ ventures to 
explain in plain words the details of 
this ISO format. 
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APPLICATION NOTE 


Owing to its integrated con- 
troller, the MLX90308 from 
_Melexis is a very flexible 
interface that, with 
suitable software, can be 
ly adapted for use with a 
yide range of sensors. Since 
, most other needed 
components are also inte- 
ated on the IC, the device is 
ot only user-friendly but also 

: relatively inexpensive. 


Features 


< Microprocessor-controlled signal conditioning for bridge-type sensors 
« Suitable for low-cost sensors: reduction of non-linearity by programmable 
_ coefficients 
< External or internal temperature sensor for compensating temperature errors 
<» 64 byte RAM, 4 kbyte program space (ROM) available 
= 488 bit for calibration data available (EEPROM) 
«> Versatile output signal ranges: 4 V, ..., 11 Vor 4-20 mA loop 
< Mass calibration easy with 2400 or 9600 baud UART 
_ « Power supply from 5 V to 35 V 


DESCRIPTION 

The most noteworthy property of the 
MLX90308 sensor interface is the inte- 
grated controller. This enables the 
device to be used for a very wide 
range of applications. The non-linear 
operation of many bridge-type sensors 
can be largely reduced, eliminated or 
corrected simply by programmable 
coefficients. 

Temperature errors can be com- 
pensated with the aid of an internal or 
external sensor. 

The program memory consists of 
4 kbyte ROM. For the interface, there 
are 64 bytes of RAM, and for the cali- 
bration data, there is a 48 x 8 bit EEP- 
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ROM available. 

The output may be used as 
required in the voltage mode (4-11 V), 
or current loop (4-20 mA). Since the IC 
has an internal voltage regulator, the 
supply voltage may range from 4 V to 
35 V. 

The MLX90308 also contains a com- 
plete oscillator, a power-on reset facil- 
ity, a watch dog, and a UART(2400 or 
9600 baud). 

The interface is housed in a 16-pin 
DIL case. The internal block diagram 
and pinout are shown in Figure 1. 


MODES OF OPERATION 
There are two major modes of opera- 
tion: the digital mode and the analogue 
mode. 

In the analogue mode, the output 
of the pressure sensor bridge is ampli- 
fied via IA and GN and then converted 
to the correct output signal form in one 
of the output stages. 

The sensitivity and offset of the 
analogue signal chain are defined by 
numbers passed to the digital-to-ana- 
logue converter (DAC) interfaces from 


Elektor Electronics 11/98 


} 


mrammable sensor interface 


Visit our Web site at htip://ourworld.compuserve.com/homepages/elektor_uk 


the microcontroller (GN[9:0] and 
OF[(9:0]). The wide range of bridge off- 
set and gain is accommodated by 
means of a 2-bit ‘coarse adjustment’ 


DAC in the offset adjustment 
(CSOF[1:0}), and a similar one in the 
gain adjustment (CSGN[2:0)). 

The temperature signal, TPO, gen- 
erated from the external or internal 
temperature sensor, drives an ana- 
logue-to-digital converter (ADC) inter- 
face to provide a 10-bit digital repre- 
sentation of temperature for use in cal- 
culating the main 10-bit DAC inputs. A 
similar 2-bit ‘coarse adjustment’, 
GNTP[L:0] is also required for the tem- 
perature signal gain and offset. 

In the digital mode, the analogue 
sensor signal is converted to digital 
information before being processed by 
the microcontroller. It is then con- 
verted with the 10-bit DAC and finally 
directed to the output. 


ANALOGUE SECTION 
A bandgap-stabilized supply regulator 
is provided internally; the pass tran- 
sistor is external. The bridge-type sen- 
sor is typically powered by the regu- 
lated supply (typically 4.75 V). For 
ratiometric operation, the supply reg- 
ulator may be disabled by shorting the 
unregulated and regulated supply 
pins (VDD1 and VDD respectively). 
The 90308 contains a programma- 
ble on-chip RC oscillator. No external 
components are needed to set the fre- 
quency (87.8 kHz+1%) The micro- 
processor clock is generated by a 
phase-locked loop (PLL) (614 kHz or 
2.46 MHz) that locks on the basic oscil- 
lator. 
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A/D and D/A conversions using only one 
DAC 

For saving chip area, the single offset 
DAC is multiplexed in various ways. 
Both fine offset and digital mode sig- 
nals are stored on a capacitor. An ADC 
loop is available via a 10-bit multi- 
plexer (see also Figure 1). 


Digital-to-analogue 

Before changing to another capacitor, 
the DAC output must be settled to the 
new value. So, MODSEL moves the 
analogue multiplexer to the so-called 
‘open-state 0. At the same time, the 
10-bit multiplexer selects OF[9:0] for 
the offset DAC. After the DAC settling 
time, the analogue multiplexer is 
moved to its final state and the DAC 
output is stored on a capacitor. 


Analogue-to-digital 

The S/W signal MODSEL connects the 
SAR output to the DAC and the DAC 
output to the comparator. The SAR 
register is initialized by a leading edge 
of STC (S/W signal). At the end of the 
A/D conversion, the EOC flag is set to 
1 and the controller can read the ADC 
values. 


Power-on reset 

The power-on reset initializes the state 
of the digital part after power up. This 
reset procedure has two phases—see 
Figure 3. The reset level is typically 
3.5 V, while the delay time is given by: 


Ty elay ~ 28 /frCosc: 


Test mode 
For 100 per cent testability, a TEST pin 
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(3) is provided. When this pin is pulled 
low, the monitor program is entered 
and the chip changes its functionality. 
In all applications, this pin should be 
pulled high or left floating (there is an 
internal pullup resistor). 


MICROPROCESSOR 

AND DIGITAL SECTION 
The Type LX11 microcontroller core is 
well specified elsewhere (for instance, 
in Melexis’ Standard Products Book) and 
will therefore not be discussed in detail 
in this short article. It has the follow- 
ing features: 


= two accumulators, one index, and 
two interrupt accumulators 

= 8-bit I/O ports (see below) 

= wait mode is not implemented 

= 64 byte RAM 

= 4 kbyte ROM; 3 kbyte is available 
for the user’s application firmware 
(changed with one mask only); 
1 kbyte is reserved 

= 48x8-bit EEPROM, which is acces- 
sible only via the I/O ports (see 
below) 


I/O ports 

The 90308 microcontroller has 15 port 
addresses. Read and write operations 
to the same address do not access the 
same port. In other words, there are 15 
input ports (only six used) and 15 out- 
put ports. See Table 1. 


Interrupt controller 

The 90308 has four interrupt sources: 
two UART interrupts and two timers. 
When these sources are enabled (out- 
put port), the LX11 core is sent to 
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interrupt address 21h 
upon interrupt occur- 
rence. The interrupt 
signals are situated in 
input/output port 2. 
All interrupts are reset 
to zero upon a write or read access to 
port 3. It is up to the user to read the 
interrupt bits or not. 

Note that if the interrupt is not 
read, the interrupt controller will be in 
a state being the OR of the previous 
states. 


UART 
The serial link is a potentially full- 
duplex UART. It is receive-buffered, 
which means that it can receive a sec- 
ond byte before a previously received 
byte has been read 
from the receiving reg- 
ister. However, if the 
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first byte is not read by 
the time the reception 
of the second byte is 
completed, the first 
byte will be lost. The 
UART’s baud rate 
depends on the RC oscillator’s fre- 
quency and the TURBO bit (see 
Table 2). The transmitted and received 
data has the following structure: start 
bit = 0; eight bits of data; stop bit = 1. 
Sending data: 
¢ Writing a byte to port 1 automati- 
cally starts a transmission sequence. 
¢ The TX interrupt is set when the 
STOP bit of the byte is latched on 
the serial line. 
Receiving data: 
* Reception is initialized by a 1 to 0 
transition on the serial 
line (i.e., a START bit). 
* The baud rate 
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period (i.e., the duration of one bit) 
is divided in 16 phases. The first six 
and last seven phases of a bit are of 
no use. The decision on the bit- 
value is then the result of a major- 
ity vote of phases 7, 8 and 9 (ie., the 
centre of the bit). 

* Spike synchronization is avoided 
by debouncing on the incoming 
data and a verification of the 
START bit value. 

* The RX interrupt is set when the 
STOP bit is latched in the UART. 


Timer 

The clock of timers TMI and TPI is 
taken directly from the main oscillator. 
The timers are never reloaded, so the 
next interrupt will take place 2% oscil- 
lator pulses after the first interrupt. 


Watch dog 

An internal watch dog will reset the 
whole circuit in case of a software 
crash, When the watch dog counter is 
not reset at least once every 26 ms 
(with a main clock frequency of 
2.46 MHz), the microcontroller and all 
the periphery will be reset. 


Demonstration material 

A complete set of demonstration mate- 

rial is available to bona fide designers 

upon request. It contains: 

* 10 samples 90308 with versatile 
demonstration firmware 

* a demonstration board 

¢ aserial cable for connection to a PC 

* special software for communication 
and calibration 
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* a demonstration description 

With the demo set, a working sensor 
interface can be built and calibrated 
without too much effort. 


Application specific firmware 

For the development of application 

specific firmware, a special version of 

the 90308 with an external ROM inter- 

face is available. This version also fits 

in the demonstration board and can be 

used as such to develop and debug 

new firmware. The external ROM is 

then replaced typically by an external 

EPROM or an emulator of ‘Crash Bar- 

rier’. A complete software develop- 

ment toolset is also available—see Fig- 

ure 4. It contains: 

< Complete demonstration set: see 
above 

«= An assembler: AS 

© A relocator and linker: LYN 

=~ AROM file generator: OBSEND 

@ A customizable simulator: SIM 

« An emulator: Crash Barrier 
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Table 1. Input-ports 


msb-2| msb-3 


EEI5 | EEI4 


RX4 | RX3 
PTPI 
IRQ1 | IRQO 


EEI3 | EeI2 | EEN | 


SOURCE CODE FILE 


OTHER OBJECT 


portname 


= cl 


jf 7 fe] s | 4] 3 | 2} + | o |btmmbers | 
-4| msb-5 


EEI1 


PTMI/ | PUTI | PURI |interrupt register 
ae TESTB ce cel register 


ae Leen read 
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ADC input 1 
ADCO | ADC input 2 


OBJECT 


CODEFILE 
OBSEND 


TO EMULATOR, 
SIMULATOR, 


EPROM PROGRAMMER 


[ INCLUDE FILE ] 
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Table 3. Absolute maximum ratings 


VDD1 (regulator active): 
VDD (regulator disabled): 


Die temperature: 
Storage temperature range: ~65 °C to +150 °C 


35 V 
7V 
+160 °C 


Working temperature range: -40 °C to +140 °C 


Supply current (at 25 °C ambient): 


ADC7 | ADC6 | ADCS | ADC4 | ADC3 | ADC2 current mode: 24mA 
voltage mode: 5 mA 
Table 2. Output-ports 
7 6 5 4 3 2 1 0 bitnumber 
port msb msb-1 msb-2 msb-3 msb-4 msb-5 msb-6 Isb portname 
0 DIGMPD OUTM?1 OUTMO WDTSTA ETP! ETMI EUTI EUR! UARTMR contro! 
1 TX? TX6 TX5 TX4 TX3 TX2 TXT TXO UART transmit 
2 ATPI AURI interrupt register 
4 EEO7 EEO6 EEOS EEO4 EEO3 EEOQ2 EEO1 EEOO EEPROM write 
5 EEAS EEA4 EEA3 EEA2 EEA1 EEAO EEPROM address 
6 VEE? VEEO EBW EBE EWR ERD EER EEPROM control 
7 CADJ7B CADJE CADJ5 CADJ4 | CADJ3 CADJ2 CADJ1 CADJO clkaqj register 
8 OFBUFPD DARDIS OBP1 OBPO j BPDSEL1 BPDSELO | BPASELT BPASELO | output i! register 
i] GNS GN8& GN7 GN6 i GN5 GN4 GN3 DACGN | register 
10 DACGN HI register 
11 OF9 OF8 OF7 OF6 OF5 OF4 OF3 OF2 DACOF | register 
12 DACOF I! register 
13 INV GNTP1 GNTPO CSOF1 CSOFO CSGN1 output Ill register 
14 TURBO INEXTP output IV register 
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KEELOQ RKE Code Hopping Decoder 


Microchip’s new 
KEELOQ Code hop- 
ping Decoder has 
been developed for 
highly secure re- 
mote-keyless-entry 
(RKE) and access 
control applications. 


The new HCS515 offloads all 
timing and processing-inten- 
sive functions from the micro- 
controller, reducing the code 
space and bandwidth re- 
quired by the system con- 
troller when handling the in- 
coming RF signal. The device 
provides a complete decoding 
solution, handling reception 
and validation of codes and 
recognising new transmitters. 
The new device combines 
high-security, a small package 
outline and low cost to make 
it the ideal solution for appli- 
cations such as automotive 


alarm systems and immobilis- 
ers, gate and garage door 
openers, burglar alarm sys- 
tems, and electronic door 
locks. 

Accommodating up to seven 
transmitters, the HCS515 pro- 
vides encrypted storage of 
manufacturers and transmitter 
keys, and storage of other 
transmitter parameters. The 1- 
kBit of user EEPROM is ac- 
cessed through the same 2- 
wire interface used to com- 
municate with the decoder. A 
4-MHz on-board oscillator 
eliminates the need for exter- 
nal components. 

The HCS515 operates over a 
wide voltage range of 3.0- 
5.5 volts. The decoder em- 
ploys automatic bit-rate de- 
tection, allowing it to com- 
pensate for wide variations in 
transmitter data rates. The de- 
coder contains sophisticated 
error checking algorithms to 
ensure only valid codes are 
accepted. The device is com- 
patible with Microchip’s six 
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KEELOQ encoder solutions. 
Microchip's HCS515 is avail- 
able in 14-pin SOIC and PDIP 
packages, and is supported 
by a device programmer and 
development evaluation 
board kit. 


Arizona Microchip Technology 
Ltd., Microchip House, 505 
Eskdale Road, Winnersh Tri- 
angle, Wokingham, Berks 
RG41 STU. Tel. (0118) 921 
5858, fax (0118) 921 5835, 
(987189) 


Battery identification/monitor chip 


The DS2436 from 
Dallas 
Semiconductor pro- 
vides reliable pro- 
tection for recharge- 
able batteries and 
end systems. The 
device mounts 
directly in the bat- 
tery pack with mini- 
mal interconnects. 


Dallas Semiconductor 
recently introduced a single 
chip that monitors battery 
parameters and stores perti- 
nent data for battery identifi- 
cation and charge control. 
Integrating a 10-bit voltage 
A/D converter, temperature- 
sensing circuitry, and non- 
volatile memory, the DS2436 
Battery Identification/Monitor 
Chip is designed for use as a 
data-acquisition system for 
batteries. 


The DS2436 combines four 
functions: temperature sens- 
ing, non-volatile data storage, 
battery identification and bat- 
tery voltage monitoring. 

Battery packs equipped witha 
DS2436 carry their identifica- 
tion parameters and manufac- 
turing data in 256 bits of non- 
volatile memory. The device 
uses this information to distin- 


7 in 


guish OEM batteries from 
clones, ensuring safe and effi- 
cient battery charging. The 
DS2436 is a chemistry-inde- 
pendent device: the host's 
firmware can use temperature 
and voltage data for charge 
termination and fuel gauging. 
A cycle counter manages bat- 
tery maintenance intervals 
and functions as a wear-out 
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indicator. 

The DS2436 uses Dallas 
Semiconductor's proprietary 
1-Wire™ technology to 
reduce the number of inter- 
connects required for opera- 
tion to three: data, power and 
ground. With these minimal 
interconnects, the DS2436 
can be mounted directly in 
the battery pack, reducing 
tooling costs and board 
space consumption. 

The battery ID chip measures 
battery voltage from 2.7V to 
10V, eliminating the need for 
an external A/D converter or 
MUX. Applications in portable 
electronics include cell- 
phones, laptop/palmtop com- 
puters, audio/video equip- 
ment, data loggers, inventory 
scanners, and other hand- 
held instruments. 


Dallas Semiconductor, 4401 
South Beltwood Parkway, 
Dallas, Texas 75244-3292. Tel. 
(+1) 972 371-4448, fax (+1) 
972 371-3715. 

(987252) 
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Compact 500W dry loads 


and attenuators 


A new series of 
high-power RF loads 
and attenuators is 
now available from 
Bird Component 
Products. 


The new devices feature an 
extremely compact and light- 
weight design, low VSWR and 
economical price. The 500 WT 
Series includes models to ei- 
ther terminate or attenuate up 
to 500 watts of RF energy. 
With a frequency range of DC 
to 2.5 GHz, the new units can 
be used on cellular, data, ISM, 


Land Mobile, paging, PCS 
and SMR/ESMR applications, 
The 500W Series are dry, con- 
vection cooled devices that 
weigh approximately 3.6 kgs. 
The loads measure approxi- 
mately 26.3Lx13.7 Wx 11 
H cm, and the attenuators, ap- 
proximately 28.4 L x 13.7 W x 
11 H cm. The finish is black 
anodised aluminium. Available 
tri-alloy plated connectors are 
IEC 7/16, N or TNC. 

The units offer considerable 
placement flexibility because 
they can be mounted in any 
position except surface-up. 


Bird Component Products, 50 
West Jefferson St., Franklin, 


IN 46131, USA. 
Tel. (+1) 317 346 6600, 


fax (+1) 317 346 6601. 
(987253) 


Drag and drop your innovations with 
the IdeaFactory 


Quickroute’s latest 
software product, 
the IdeaFactory, is 
an amazing new 
‘idea simulator’ 
product which offers 
even the non-techni- 
cal a new way to 
drag-and-drop inno- 
vative, interactive 
multimedia models. 


Using the ldeaFactory you 
can create animated simula- 
tions on screen, and explore 
technology, science, electron- 
ics and maths in an innova- 
tive, fun and interactive envi- 
ronment. 

The IdeaFactory allows you to 
load and visualise data in real 
time, create and interact with 
simple (or complex) models. 
Explore electronics and logic, 
and combine animations with 
sound to produce amazingly 
sophisticated models. Virtual 
instruments, 2D and 3D 
charts, on-screen switches, 
lights and keypads combined 
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with maths and electronics 
objects in an intuitive way. 
Whether it’s creating animat- 
ed object games, modelling a 
physics experiment, or de- 
signing a logic system, The 
IdeaFactory is there to help. 


Quickroute Systems Ltd., Re- 
gent House, Heaton Lane, 
Stockport SK4 1BS. Tel. 
(0161) 476 0202, fax (0161) 
476 0505. Email: 
info@quicksys.demon.co.uk. 
Web site: 
www.quickroute.co.uk 

(987258) 
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ELECTRONICS 


GENERAL 


E-ROUTER-1, CD-ROM with 20+ Elektor designs 

you can modify yourself. Incl, Edwin NC working 

demo. 23.00 46.00 

ESPRESSO. companion CD-ROM for ‘Digital 

Signal Processing’ course 13.00 26.00 

ELEKTOR ELECTRONICS VOLUME 1997 ON CD-ROM, 

incl Blectrames Workbench 

working demo 31,50* 63.00" 

* reduced price for subscribers. Normal price: £35.50 or 
US$71.00 

ELEXTOR ELECTRONICS ITEM TRACER 1985-1997. 

(on 3.5-inch floppy disk)  986011-1 10.00* 20.00* 

* reduced price for subscribers. Normal price: £11.75 or 
US$23.50 

ELEKXTOR ELECTRONICS 'pP-C HARDWARE & 

SOFTWARE 97-98 ON CD-ROM 

Compilation of 100+ prize-winning entigs from our 1997 

Microprocessor Design Competition, Disclaimer, 

software Supplied as 1s, 

not tested by Elektor 986001-1 16.50 33.00 

ELEKTOR ELECTRONICS DATASHEET COLLECTION 

1 ON CD-ROM 13.00 26.00 

ELEKTOR ELECTRONICS DATASHEET COLLECTION 

2 ON CD-ROM 13.00 33.00 

ELEKTOR ELECTRONICS VOLUME 1996 ON CD-ROM. 

incl. Electronics Workbenct 

working deme 31.50" 63.00* 

* reduced price for subscribers, Normal price: £35.50 or 
US$71.00 

£LEKTOR ELECTRONICS VOLUME 1995 OW CD-ROM 

37.00* 74.00* 

* reduced price for subscribers Normal price £41.00 or 
US$82,00 

ELEXTOR ELECTRONICS SOFTWARE COMPETITION 

1996/97 ON CD-ROM. 

Compilation of all prize-wanning entries. Disclaimer: 

software supplied as js, not 


tested by Elektor 976003-1 16.75 31.50 
ELEKTOR ELECTRONICS HELP DISK. 

NOVEMBER 1998 

Smartcard-Operated Cade 

Lock 

- PCB & PICT6FAd 980061-C 25.25 50.50 
+ PIC only 986511-1 18.75 37.50 
- PCB only 980061-1 8.25 16.50 
Master’Slave Switch DeLuxe 982063-1 975 19.50 
PC Control for MiniDisk 

Player: 

- PCB & AT89C2051 980092-C 22.50 45.00 
- AT89C201 only 986516-1 16.75 33.50 
- PCB opnily 980092-1 7.25 14.50 
Barometer/Altimeter 

- PCH & disk 980097-C 15.00 30.00 
- PCB only gangg7-1 11.75 23.50 
- Disk only 986031-1 5.00 10.00 
4 compact Display Controller 

- AT90S1200 & disk 980096-C 22.50 45.00 
- Disk only 986030-1 10.25 20.50 
- ATS0S1200 only 986521-1 1375 27.50 
OCTOBER 1938 

Rey Counter with LEDs 980077-1 B.75 17.50 
418/433MHz Fieldstrength 

‘Meter 9a0ds3-1 6.25 12.50 


PAST ISSUES 


‘ice in Dowchester 


Versatile Control System 


PLO87{A} 

- PCB only 980066-1 
- Disk only 986026-1 
- 87C51 (digital version) 986513-1 


870550 janalogue version) 98651 4-1 
Digital Chipping Indicator 980072-1 
AVR-RISC Evaluation System 


- PCB & disk 980082-C 
- Disk only 986020-1 
Refrigerator Economizer 980052-1 
SEPTEMBER 1998 
Active Magnetic Antennas = =980062-1 
Experimental Power Supply 

for PCs 980057 -1 
Multiple Test Card for 

Microcontrollers 980074-1 


418/433MHz Control System 
- 1 Transmitter PCB & 1 


Receiver PGB (set) 980063-C 
- Transmitter PCB only 980063-1 
- Receiver PCB only 980063-2 
JULY & AUGUST 1998 
Simple Copybit Killer: 
- PCB & EPROM 970069-C 
- PCB only 970069-1 
- EPROM only $76516-1 
Maintenance Charger 970092-1 
RC5 Remote Control 
Extension 970047-1 
Doorbell-Contralled Burglar 
Deterrent Light 984029-1 
PIC 16CB4 Programmer for 
Centronics Port 984036-1 


Mains Master/Slave Control 
Mk2 984052-1 
Low-Cost Development 


System for PICs 984060-1 
LED Barometer 984061-1 
Electronic Spirit-Level 984038-1 


Simple Infra-Red Transmitter 984049-1 
100-watt Singie-IC Amplifier 984062-1 
Extension Board for MatchBox 

BASIC Computer 984028-1 
Automatic Air Humidifier 984087-1 
Centronics In-System Programmer: 


- Disk only 986023-1 
Berlin Clack: 

- Disk only 986016-1 
- PIC only 986508-1 
JUNE 1998 

PIC & AVR Programmer: 

- PCB, PIC and disk 980049-C 
- PCB only 980049-1 
- PIC only $86509-1 
- Disk only 986019-1 
RS232 Controtlec 8-Channel Switch 

- PCB only 

- Disk only (VB3 program) 986015-1 
Liquid-Level Gauge: 

- PCB only 

- $162T20 and Disk 970056-C 
- $1627.20 only 976515-1 
- Disk only (Source code) = 970515-1 
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23.00 


26.00 
15.00 
16.50 


49.50 
21.50 
31.50 
13.00 


15.50 
18.00 
16.50 
18.50 
28.50 
11.50 
14.50 
14.50 
15,00 


19.50 


7.75 15.50 


33 25 
12.25 
15.25 
8.75 


19,00 


14,50 


5S 30.60 


56.50 
24.50 
30.50 
17.50 


Not Available 


6.50 


13.00 


Not Available 


19.00 
15.75 
5.0 


38.00 
31.50 
19.00 


PICXEX Operating System 

for PICs: 

- Disk only 986017-1 
Monitor TV Refresh Rate Meter; 

- PCB only 980040-1 
- AT90S1200 only 986510-1 
Fibre-Optic Data 

Communication 980042-1 
APRIL 1998 

PC-Aided BJT Tester Revisited: 

- PCB & disk 980022-C 
- disk only 986005-1 
20-metre CW/SSB 

Receiver 980036-1 
Mains Filter with 

Overvaliage Protection 982032-1 
Electric Fieidstrength 

Meter 980039-1 
MARCH 1998 


ESPRESSO, Introduction to Digital 
Signal Processing {CD-ROM} 986004-1 


80032 BASIC Computer: 

- Main board 980002-1 
- Extension board 980002-2 
- Disk 986007-1 
- EPROM 986503-1 
Data Acquisition System 

- PCB 

- Disk (source code files) 986013-1 
- ATB9CS2 controller 986504-1 
IC Tester: 

- PCB, disk, GAL & EPROM 980029-C 
- PCB only 980029-1 
- Disk only 986014-1 
- GAL only 986506-1 
- EPROM only 986507-1 
Variable Power Supply 980024-1 


Balanced/Unbalanced Converters 
for Audio Signals 980026-1 


FEBRUARY 1998 
Frequency Display & VFO Stabilizer 


- PCB only 980004-1 
+ PIC only 986502-1 
- Disk only 986006-1 
AVC for PCs 980023-1 
Functional Trinket 980025-1 


Light Intensity Measurement with a PC 


- Disk only 986002-1 
JANUARY 1998 

Portable Sound Pressure 

Meter 970085-1 
Stereo Microphone Input 

Adaptor for PC 980007-1 
Electronic Die 980021-1 


DECEMBER 1997 
Running Lights for Christmas 
- PCB & 8751 70086-C 
- 8751 only 9765171 
Handyman‘4T9081200 Programmer: 
- Docking station PCB, shuttie 

PC8, diskette 970090-C 
- Docking station PCB only +970090-2 
- Handyman shuttie PC8 only 970090-1 


~ Diskette only 976017-1 
Smartcard ReaderWriter 

~ PCB, disk & PIC16C84 970068-C 
- PIC+6C84 only 976512-1 
- Disk only 976014-1 
PIC Controlled Light Barrier: 

- PCB 

- PIC only $76503-1 
NOVEMBER 1997 

Hygrometer 970065-1 
Video Copy Processor: 

- PCB & EPM7032 970066-C 
~ EPM7032 only 976514-1 


Stereo Microphone Amplifier 970083-1 
PC as 4-channel Logic Analyser; 
- PCB 


- software on disk 976012-1 
OCTOBER 1997 

4-Way Serial Port Switch 970057-1 
12-bit ADC Interface: 

~ PCB and disk 970060-C 
- Disk only (also for 

CPU Thermometer) 976011-1 

Infra-re¢-Controlled 

Noise-less Volume Control = 970064-1 
Frequency Meter and Event 
Counter Module: 

- PCB and PIC16C56 970077-C 
- PIC only 976505-1 
DC Nullifier for Oscilloscope 
Input 

- PCB 970DB3-1 
- PZ5032 CPLD chip 976513-1 
- Disk only 976016-1 
Directional Microphone 970079-1 
SEPTEMBER 1997 
Oata Acquisition System 

~ PCB, EPROM ane disk 970059-C 
- EPROM only 956510-1 
» disk only 9580+0-1 


13.00 


10.25 
15.00 
5.00 
9.75 


51,60 


20.00 
15.00 


14,00 


40.50 
20.50 


23.50 
16.00 


16.00 


26.00 


20.50 
30.00 
10.00 
19.50 


Not Available 


8.25 
24.25 


35.00 
21,00 
5.00 
5.75 
8.25 
10.50 


41.50 


28.25 
19.00 


20.25 
7.50 
4.25 

11.75 


35.00 
19.50 
8.75 


16.50 
48.50 


70.00 
42.00 
10.00 
11.50 
16.50 
21.00 


23.00 


56.50 
38.00 


40.50 
15.00 

8.50 
23.50 


70.00 
39.00 
17.50 


Not Available 


14.75 


11.00 


34.75 
27.50 
19.25 


29.50 


22.00 


69.50 
55.00 
38.50 


Not Available 


8.75 


12.00 


10.50 


17.50 


24.00 


21.00 


11.50 


22.00 


68.50 
51.00 


25.00 
40.50 
10.00 
16 50 


66.00 
24.50 
17.50 


- disk only 976010-1 
JULY/AUGUST 1997 

AGB Video Amptitier 974042-1 
Digital Tester 974012-1 
LM2574 Switch-Mode 

Power Supply 974024-1 
Selective Door Chime 9740251 
Yamaha OBSOXG 

Stand-Alone Soundcard 74100-1 


JUNE 1997 
800537 Microcontroller Board 


- PCB, GAL & EPROM 970048-€ 
- GAL only 976511-1 
- EPROM only 976510-1 
- Monitor doc file on disk  976008-1 


Remote Control by Telephone: 
- program an disk 
Car Battery Monitor 


976005-1 
970025-1 


Mult-Purpose LCD with 68HC 14 

- control program on disk = 976009-1 
Mini PIC Programmes and 

Mini Programmer for Serial EEPROMs: 


- PIPO2 software on disk © 976007-1 
MAY 1997 
Long-Distance IrDA Link 
- PCB & 8902051 970041-C 
~ 8902051 only 976508-1 
Advanced LCR Meter: 
- PCB, GAL + EPROM 970028-C 
- GAL 22V10 976506-1 
- EPROM 270512 976507-1 
~ Front panel foil 970028-F 
Wideband Millivolt Meter 70021-1 
Compact Power Amplifier 970043-1 
APRIL 1997 
Digital Thermostat: 
+ PCB & PIC16054 960112-C 
- PICI6C54 only 966501-1 
uP-Controlled Mixer Board 
~ PCB & ST62T25B 970037-C 
- 8T62T25B only 976502-1 
- POB only 970037-1 
- Software on floppy (AD) 976006-1 
PIC-controlled Home Alarm 
System 
- PCB & PIC 16084 970022-C 
- PIC16CB4 only 976501-1 
General-Purpose Power 
Supply 970036-1 
Opto-ta-Coanal Audio 
Converter 970031-1 
MARCH 1997 
EPROM Programmer: 
- PCB 970010-1 


- Contro! software 
Battery-Operated AF Signal 
Generator 970003-1 
FEBRUARY 1997 

Battery-Powered Preamplifier 960094-1 
Motor Controller for R’C 

Models: 


» PCB and PIC1BC84 960095-C 
~ PIC 16084 only 966510-1 
68HC11 Emulator 

- PCB and diskette 970008-C 
- Diskette only 9760021 
Simple Inductance Meter 

- PCB and diskette 970009-C 
- Diskette only 976001-1 
Talking Doorbell 970015-1 
JANUARY 1997 

Dongle Switch 960089-1 
Magnetic -Field Meter 960100-1 
Speed Regulator for Model 

Trains 960113-1 
Monitor 10 Guard Fridge 

Temperature 970001-1 


8.50 
12.25 
19.25 


7.50 
8.50 


14.75 


17.00 
24.50 
26.50 


15.00 
17.00 


29,50 


58.00 116.00 


14.75 
14.00 
8.00 
75 
16.50 
11.25 


5.50 


25.25 
17.50 


29.50 
28.00 
16.00 


17.50 
33.00 


50,50 
35.00 


62.50 125.00 


26.50 

776 
13.50 
21.50 
19.75 


92.50 
22.50 


32.75 
24.50 


10.25 
6.00 


30.50 
23.50 
3.50 


7.00 


15.75 


10.00 


34.25 


22,75 


19.00 


28.00 
11.25 


15.25 


875 
10.50 


7.00 
6.50 
850 


8,00 


For availability of older items, please contact our 


Dorchester office 


53.00 
15.50 
27.00 
43,00 
39.50 


65.00 
45.00 


65 50 
49.00 
20.50 
12,00 


61.00 
47,00 
47.00 


14.00 


31.50 


on CD-ROM no. 976003-1 


20,00 


68.50 


45.50 


38,00 


56.00 
22.50 


30.50 
17.50 
21.00 


14.00 
17.00 


Elektor Electronics slipcase 


Price £2.95 + P&P (see reverse of Order Farm} 


Elektor Electronics 


11/98 


NOME 


We make our programmers 
work harder 


FEATURES 


Supports EPROMs, EEPROMs, Flash, 
Serial PROMs, BPROMs, PSDs, PALs, 
GAls, PEELs, MACH, MAX, EPLDs, and 
over 200 Microcontrollers including 
87C48/51, 89C51/52, PIC, 
MC705/711, ST6, Z86, COP etc. 


@ Hands free programming so you can 
produce batches of the same chip 
without pressing a key 


@ Correct programming and verification 
at 1.8, 2.7, 3.3 and 5V 


@ Serial number mode supports 
date/time stamping, unique IDs 


@ Progress indicator shows number of 
devices programmed 


@ No adapters required for DIL parts 
upto 48-pins. Universal adapters for 
44-pin PLCC, 44-pin PSOP and 48-pin 

_ TSOP parts 


@ Programmes and verifies Intel 
28F400 in under 15 seconds 


Connects to parallel port - no PC 
cards needed 


@ Tests 7400, 4000, DRAM and SRAM 
@ Mains or battery operation 


@ FREE software device support 
upgrades via bulletin board and www 


MICROMASTER 
48 


NEW Windows ‘95™ 

Software provides the 

best user interface on 
the market 


NEW - Hands free 


programming 


48-pin universal 
programmer 


SPEEDMASTER GLV32 £695 


SPEEDMASTER/ 
MICROMASTER 


EPMASTER LV 


LV40 PORTABLE 


LV40 PORTABLE J £995 


For a copy of our catalogue giving full details of programmers, emelators, erasers and adapters, call, fax or e-mail us. 
You can also access our BBS or Home page. All oer products are in stock now for next day delivery - call our credit card hotline now. 


ICE Technology Ltd. Penistone Court, Sheffield Road, Penistone, Sheffield, UK $36 6HP 
Tel: +44 (0)1226 767404 Fax: +44 (0)1226 370434 BBS: +44 (0)1226 761181 (14400, 8N1) 
Web: www.icetech.com. Email: sales@icetech.com 


c€ 


40-pin programmer range 
(see website or call for 
model details) 


40-pin EPROM/Flash 
programmer 


As Micromaster LV, plus 
completely portable with 
built in keypad and 
LCD display. 


Programming Speeds 


the fastest in the 
business: 28FOO8 
in 29 sec 


EMULATOR OPTIONS 
FOR ALL PC BASED PROGRAMMERS 


128kx8 ROM/AAM 
emulator with modify on 
the fly feature Upgradable 
to 512x8 


LVECEMUL8 


etal 
9, Emulation, Testing 


SY to use application, 


Programmin 
all in one ea: 


Full sup 


port for ice- ee: 
features device-specific 


Store your favourite Projects... 


48-pin Universal Programmer 
STILL ONLY 


£69 


GANG PROGRAMMERS 


SPEEDMASTER 
GLV32 


B-way 32-pin 
EPROM/Flash Gang'Set 
programmer 


4 


128x16 ROM/RAM 
emulator with modify on 
the fly feature Upgradable 
to 512x16 


LVECEMUL16 


£195 


All orices exclude VAT and delivery 


See for yourself - download a demo from our Website at wwwicetech.com 
ORDER NOW - ALL PRODUCTS IN STOCK. CREDIT CARD ORDERS: 01226 767404 


SPEEDMASTER 
GLVCOP 


SOCKET 
ADAPTERS 


8-way 40-pin gang 
programmer for National 
Semiconductor COP 
micros 


Full range of adapters for 
PLCC, SOIC, TSOP, PSOP 
etc. 


Y 
of 


